什么是Android SQLite
SQLite是一个关系型数据库管理系统,这个库是在用户空间运行的,因此,不像MySQL等需要在程序中安装对应的服务来进行通讯。SQLite虽然是个很小巧的数据库,但是在Android平台上面,使用得却是异常广泛。因为SQLite的轻便性能特别适合在移动设备上面承载一些小型的数据管理,并且它的设计很符合Android系统的设计。
Android SQLite的应用场景
针对储存半结构化或非结构化数据,如配置文件、用户数据、环境变量等信息。
非常适用于本地APP运行数据的存储。如果需要将数据共享,可以使用SQL、Web API等技术。
Android SQLite基础操作
创建SQLiteOpenHelper类
SQLiteOpenHelper类是Android提供的一个帮助类,它提供了一个获取数据库实例的方法,并且它可以让我们很方便的打开数据连接。创建SQLiteOpenHelper 类,我们需要继承它并且实现其抽象方法,如下:
public class MyDatabaseHelper extends SQLiteOpenHelper { private static final String DB_NAME = "test.db"; // 数据库名称 private static final int DB_VERSION = 1; // 数据库版本号 public MyDatabaseHelper(Context context) { super(context, DB_NAME, null, DB_VERSION); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL("CREATE TABLE IF NOT EXISTS t_user (_id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, age INTEGER DEFAULT 0);"); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL("DROP TABLE IF EXISTS t_user;"); onCreate(db); } }
在上述代码中,我们创建了一个继承自SQLiteOpenHelper的自定义帮助类MyDatabaseHelper,实现了其两个方法onCreate和onUpgrade,其中,onCreate方法会在首次创建数据库时被调用,用于在数据库中创建相关的表和列。onUpgrade方法会在当前数据库版本较低时,被SQLiteOpenHelper调用。
打开或创建数据库
通过继承自SQLiteOpenHelper并实现部分方法,我们可以打开或创建数据库,并进行相应的操作,如下:
MyDatabaseHelper dbHelper = new MyDatabaseHelper(context); SQLiteDatabase db = dbHelper.getWritableDatabase();
在上述代码中,我们创建一个MyDatabaseHelper实例,并调用其getWritableDatabase方法,获取可写的数据库连接(如若只读请改用getReadableDatabase)。如果数据库不存在就会自动创建,否则直接打开该数据库,并返回一个SQLiteDatabase实例。
插入数据
SQLite提供了insert()方法可以插入数据,当然,在插入数据之前我们还需要创建对应的表和列。
SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("name", "张三"); values.put("age", "25"); db.insert("t_user", null , values);
在上述代码中,我们首先获取到一个SQLiteDatabase对象,然后创建ContentValues对象,将要插入的数据封装进去。最后,我们调用insert方法把数据插入到表t_user中。
查询数据
SQLite提供了query()方法来查询数据,该方法有多个重载方法来满足不同的查询需求。在这里我们看下最常用的两种查询方式:
查询所有数据:
SQLiteDatabase db = dbHelper.getWritableDatabase(); Cursor cursor = db.query("t_user", null, null, null, null, null, null); if (cursor.moveToFirst()) { do { String name = cursor.getString(cursor.getColumnIndex("name")); int age= cursor.getInt(cursor.getColumnIndex("age")); Log.d(TAG, "name: " + name + ", age: " + age); } while (cursor.moveToNext()); } cursor.close();
在上述代码中,我们调用了query()方法来查询t_user表中所有的数据,并使用Cursor对象遍历结果,从每行中提取所有数据的name和age字段。查询完成后,需要记得调用close()方法来关闭Cursor对象。
按条件查询数据:
SQLiteDatabase db = dbHelper.getWritableDatabase(); Cursor cursor = db.query("t_user", null, "age>?", new String[]{"18"}, null, null, null); if (cursor.moveToFirst()) { do { String name = cursor.getString(cursor.getColumnIndex("name")); int age= cursor.getInt(cursor.getColumnIndex("age")); Log.d(TAG, "name: " + name + ", age: " + age); } while (cursor.moveToNext()); } cursor.close();
在上述代码中,我们传递了参数来获取符合指定条件的行。query()方法的第3个参数为where子句,而第4个参数是where子句的每个参数的值。在这里,我们只返回age字段大于18的所有人的姓名和年龄。
修改数据
SQLite provides update()方法来更新数据。在更新记录之前,我们需要先找到将要更新的记录。在这里我们看下最常用的两种更新方式:
更新一个字段:
SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("name", "李四"); db.update("t_user", values, "_id=?", new String[]{"1"});
在上述代码中,我们修改id为1的行中的name字段,并将它的值设为“李四”。
更新多个字段:
SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("name", "王五"); values.put("age", "30"); db.update("t_user", values, "_id=?", new String[]{"1"});
在上述代码中,我们修改id为1的行中的name和age字段,分别赋值为“王五”和“30”。
删除数据
SQLite提供了delete()方法来删除数据,该方法的第一个参数是表名,第二个参数是where子句,第三个参数是where子句的每个参数的值。在这里我们看下最常用的方式:
SQLiteDatabase db = dbHelper.getWritableDatabase(); db.delete("t_user", "age在上述代码中,我们删除t_user表中age小于18的所有行。