SQLite数据库是Android系统集成的一个轻量级的数据库,底层是一个数据库文件,是一个嵌入式的数据库引擎,适用于资源有限的设备上(如手机、PDA)适量数据存取。
操作SQLite数据库的步骤:
1、获取SQLiteDatabase对象,它代表了与数据库的连接。
2、调用SQLiteDatabase的方法执行SQL语句。
3、操作SQL语句的执行结果,比如使用查询返回的游标Cursor进行数据显示等。
4、关闭SQLiteDatabase,回收资源。
下面用一个简单实例来演示SQLiteDatabase的基本使用。其中,为方便阅读,数据都是手动写死的,而实际中应该根据业务需求从界面或其他地方获取,代码如下:
Activity:
package com.lovo.activity; import android.app.Activity; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.view.View; import android.widget.TextView; import com.lovo.databasetest.R; public class DatabaseTestActivity extends Activity { private TextView show; private SQLiteDatabase db; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); show = (TextView) findViewById(R.id.main_tv_show); } public void click(View v) { switch (v.getId()) { case R.id.main_btn_create_database: // 创建或打开数据库,第二个参数为null,表示使用默认的工厂 db = SQLiteDatabase.openOrCreateDatabase(this.getFilesDir() .toString() + "/user.db", null); // 打开指定数据库 // db =SQLiteDatabase.openDatabase(this.getFilesDir().toString()+"/user.db", // null,1); break; case R.id.main_btn_create_table: // 创建表 db.execSQL("create table t_user(_id integer primary key,u_name text,u_pwd text)"); break; case R.id.main_btn_insert: // 添加数据 db.execSQL("insert into t_user(u_name,u_pwd) values(?,?)", new String[] { "张三", "123" }); db.execSQL("insert into t_user(u_name,u_pwd) values(?,?)", new String[] { "李四", "234" }); db.execSQL("insert into t_user(u_name,u_pwd) values(?,?)", new String[] { "王五", "345" }); break; case R.id.main_btn_delete: // 根据指定ID删除数据 db.execSQL("delete from t_user where _id=?", new String[] { 2 + "" }); break; case R.id.main_btn_update: // 根据指定ID修改数据 db.execSQL("update t_user set u_name=? ,u_pwd=? where _id=?", new String[] { "赵六", "9527", 1 + "" }); break; case R.id.main_btn_find: StringBuffer sb = new StringBuffer(); // 查询所有数据 Cursor cursor = db.rawQuery("select * from t_user", null); // 根据指定ID查询数据 // Cursor cursor=db.rawQuery("select * from t_user where _id=1",null); while (cursor.moveToNext()) { int id = cursor.getInt(cursor.getColumnIndex("_id")); String name = cursor.getString(cursor.getColumnIndex("u_name")); String pwd = cursor.getString(cursor.getColumnIndex("u_pwd")); sb.append(id + " " + name + " " + pwd + "\n"); } show.setText(sb.toString()); break; case R.id.main_btn_close_database: if(db!=null){ db.close(); } break; } } }
布局XML:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" > <Button android:id="@+id/main_btn_create_database" android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="click" android:text="创建或打开数据库" /> <Button android:id="@+id/main_btn_close_database" android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="click" android:text="关闭数据库" /> </LinearLayout> <Button android:id="@+id/main_btn_create_table" android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="click" android:text="创建表" /> <Button android:id="@+id/main_btn_insert" android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="click" android:text="添加" /> <Button android:id="@+id/main_btn_delete" android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="click" android:text="删除" /> <Button android:id="@+id/main_btn_update" android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="click" android:text="修改" /> <Button android:id="@+id/main_btn_find" android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="click" android:text="查找" /> <TextView android:id="@+id/main_tv_show" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </LinearLayout>