随时随地阅读更多技术实战干货,获取项目源码、学习资料,请关注源代码社区公众号(ydmsq666)

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>