《实验 11 SQLite数据库的使用.doc》由会员分享,可在线阅读,更多相关《实验 11 SQLite数据库的使用.doc(5页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、【精品文档】如有侵权,请联系网站删除,仅供学习与交流实验 11 SQLite数据库的使用.精品文档.实验11SQLite数据库的使用一、实验目的1掌握创建SQLite数据库的方法;2掌握实现对SQLite数据增删改查的方法;3学会使用adb调试工具查看数据库和数据表;二、知识要点1创建SQLite数据库的方法:定义一个帮助类MyHelper继承SQLiteOpentHelper类;在MyHelper类中定义构造方法,重写onCreate()和onUpgrade()方法;在onCreate(SQLiteDatabasedb)方法中,通过参数db调用execSQL(String sql)方法执行建
2、表SQL语句;创建一个MyHelper类对象helper,调用构造方法对其进行初始化,然后由helper对象调用getWritableDatabase()方法或getReadableDatabase()创建数据库。2实现SQLite数据增删改查的方法:(1)添加数据:获取一个SQLiteDatabase对象db;通过db对象调用以下任一方法实现数据添加:a)execSQL(String sql)方法执行insert SQL语句;如:db.execSQL(“insert into table_name(column_list) values(value_list)”);b)调用insert(表名
3、,null,添加的数据values)方法:首先,定义一个ContentValues对象values,通过values对象调用put()方法将要添加的数据存入values对象,然后再通过db对象调用insert()方法,将values中的数据添加到指定的数据表中。(2)更新数据:获取一个SQLiteDatabase对象db;通过db对象调用以下任一方法实现数据添加:a)execSQL(String sql)方法执行update SQL语句;如:db.execSQL(“update table_name set column=value, where condition”);b)调用update(
4、String table,ContentValuesvalues,StringwhereClause,String whereArgs)方法:首先,定义一个ContentValues对象values,通过values对象调用put()方法将要更新的数据存入values对象,然后再通过db对象调用update()方法,指定要修改数据的表名,更新的数据values,约束更新某一行火某几行中的数据。(3)删除数据:获取一个SQLiteDatabase对象db;通过db对象调用以下任一方法实现数据添加:a)execSQL(String sql)方法执行delete SQL语句;如:db.execSQL
5、(“delete from table_name where condition”);b)调用delete(String table,String whereClause,String whereArgs)方法,指定要删除数据的表名称,以及约束删除某一行或某几行中的数据。(4)查询数据:获取一个SQLiteDatabase对象db;通过db对象调用query()方法,指定要查询的表名、列名、以及where约束条件等,并将查询结果存入一个Cursor对象中。如:Cursor cursor=db.query(表名,列名,where约束条件,为where中的占位符提供具体的,null,null,nu
6、ll);三、实验内容1创建一个Android项目,项目名称为“shiyan1101_专业_(学生姓名)”,要求:(1)自动创建Activity;(2)使用XML编写界面;(3)界面构成:4个文本框,分别用来显示提示信息“图书名称”、“图书作者”、“图书价格”、“图书页数”;4个编辑框,分别用来接收用户输入“图书名称”、“图书作者”、“图书价格”、“图书页数”;5个按钮,文本显示分别为“创建SQLite数据库”、“添加数据”、“修改数据”、“删除数据”、“查询数据”。(4)程序实现功能:点击“创建SQLite数据库”按钮,创建一个SQLite数据库BookStore.db,并创建一个数据表Boo
7、k,通过Toast显示“数据库BookStore.db创建成功!”,要求使用adb查看数据库创建是否成功。点击“添加数据”按钮,将用户在编辑框中输入的图书名称、图书作者、图书价格、图书页数等数据写入添加到数据表Book中。点击“修改数据”按钮,将数据表Book中指定的数据进行修改,条件根据题目自己设定。点击“删除数据”按钮,将数据表Book中指定的数据删除,删除条件根据题目自己设定。点击“查询数据”按钮,查询数据表Book中指定的数据,将查询结果通过Log显示。(5)实验报告中要求用语言描述具体的实验步骤,并附以截图做辅助说明。【具体过程参见课件第3部分数据存储中的练习2-6。】Mydateb
8、ase,javapublic class Mydatebase extends SQLiteOpenHelper public static final String cerat= create table if not exists book( _id integer primary key autoincrement, + name text,zuozhe text , price real,page integer ); public Mydatebase(Context context, String name, CursorFactory factory,int version) s
9、uper(context, name, factory, version);/ TODO Auto-generated constructor stubOverridepublic void onCreate(SQLiteDatabase db) / TODO Auto-generated method stubdb.execSQL( cerat);Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) / TODO Auto-generated method stub创建数据库按钮pro
10、tected void onCreate(Bundle savedInstanceState) super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);mydb=new Mydatebase(MainActivity.this, BookStore.db, null, 1);btcreat=(Button)findViewById(R.id.create);btcreat.setOnClickListener(new OnClickListener() Overridepublic void onCli
11、ck(View v) / TODO Auto-generated method stubdb=mydb.getWritableDatabase();/db.execSQL(INSERT_DATA);db.execSQL(insert into book (name,zuozhe,price,page) +Values(dnjkc,fdg,35.0,123);添加数据按钮edname=(EditText)findViewById(R.id.ed1);edau=(EditText)findViewById(R.id.ed2);edjiage=(EditText)findViewById(R.id.
12、ed3);edpage=(EditText)findViewById(R.id.ed4);btadd=(Button)findViewById(R.id.add);btadd.setOnClickListener(new OnClickListener() Overridepublic void onClick(View v) / TODO Auto-generated method stubString sname=edname.getText().toString();String sau=edau.getText().toString();Double djiage=Double.par
13、seDouble(edjiage.getText().toString();int ipage=Integer.parseInt(edpage.getText().toString();ContentValues values=new ContentValues();values.put(name, sname);values.put(zuozhe,sau);values.put(price, djiage);values.put(page, ipage);SQLiteDatabase db=mydb.getWritableDatabase();db.insert(book, null, va
14、lues);修改数据按钮btgai=(Button)findViewById(R.id.xiu);btgai.setOnClickListener(new OnClickListener() Overridepublic void onClick(View v) / TODO Auto-generated method stubSQLiteDatabase db=mydb.getWritableDatabase();db.execSQL(update book set name=孙孟也 where name=smy;);删除数据按钮btdelete=(Button)findViewById(R
15、.id.delete);btdelete.setOnClickListener(new OnClickListener() Overridepublic void onClick(View v) / TODO Auto-generated method stubSQLiteDatabase db=mydb.getWritableDatabase();db.execSQL(delete from book where name=孙孟也);查询数据按钮btcha=(Button)findViewById(R.id.select);btcha.setOnClickListener(new OnCli
16、ckListener() Overridepublic void onClick(View v) / TODO Auto-generated method stub SQLiteDatabase db=mydb.getWritableDatabase(); /查询Book表中所有的数据 Cursor cursor=db.query(Book, null, null, null, null, null, null); if(cursor.moveToFirst() do/遍历cursor对象,取出数据并打印String name=cursor.getString(cursor.getColumn
17、Index(name);String author=cursor.getString(cursor.getColumnIndex(zuozhe);double price=cursor.getDouble(cursor.getColumnIndex(price);int pages=cursor.getInt(cursor.getColumnIndex(page);Log.d(Message,book name is+name);Log.d(Message,book author is+author);Log.d(Message,book price is+price);Log.d(Message,book pages is+pages); while(cursor.moveToNext(); cursor.close();