在Android开发中,SQLite数据库是一种轻量级、嵌入式的关系型数据库,广泛应用于本地数据存储,由于SQLite无需单独的服务器进程,且直接集成在Android系统中,开发者可以方便地通过Android SDK提供的API实现数据库的创建、查询、更新和删除操作,本文将详细介绍Android如何连接SQLite数据库,包括环境准备、数据库创建、数据操作及最佳实践等内容。

SQLite数据库基础
SQLite是Android内置的数据库引擎,支持标准SQL语法,具有零配置、服务器less、自给自足的特点,每个Android应用都拥有独立的数据库文件,存储在应用的私有目录中(如/data/data/<包名>/databases/),其他应用无法直接访问,确保了数据安全性,开发者无需额外安装或配置数据库服务,只需通过Android提供的SQLiteOpenHelper辅助类即可管理数据库的生命周期。
创建数据库与表
在Android中,通常通过继承SQLiteOpenHelper类来创建和管理数据库。SQLiteOpenHelper提供了两个核心方法:onCreate()和onUpgrade()。onCreate()在数据库首次创建时调用,用于初始化数据库表结构;onUpgrade()在数据库版本升级时调用,用于修改表结构或迁移数据。
以下是一个简单的SQLiteOpenHelper实现示例:

public class MyDatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "my_database.db";
private static final int DATABASE_VERSION = 1;
private static final String TABLE_NAME = "users";
public MyDatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
String createTable = "CREATE TABLE " + TABLE_NAME + " ("
+ "id INTEGER PRIMARY KEY AUTOINCREMENT, "
+ "name TEXT, "
+ "age INTEGER)";
db.execSQL(createTable);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
onCreate(db);
}
} 在上述代码中,DATABASE_NAME指定数据库文件名,DATABASE_VERSION用于控制数据库版本,通过getWritableDatabase()或getReadableDatabase()方法获取数据库实例,若数据库不存在,则会自动调用onCreate()创建。
执行数据库操作
创建数据库后,开发者可以通过SQLiteDatabase类提供的insert()、update()、delete()和query()等方法执行CRUD(增删改查)操作,以下是具体操作示例:
插入数据
SQLiteDatabase db = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", "张三");
values.put("age", 25);
long newRowId = db.insert(TABLE_NAME, null, values); 查询数据
SQLiteDatabase db = dbHelper.getReadableDatabase();
Cursor cursor = db.query(TABLE_NAME, 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("Database", "Name: " + name + ", Age: " + age);
} while (cursor.moveToNext());
}
cursor.close(); 更新数据
SQLiteDatabase db = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("age", 26);
String whereClause = "name = ?";
String[] whereArgs = {"张三"};
int rowsUpdated = db.update(TABLE_NAME, values, whereClause, whereArgs); 删除数据
SQLiteDatabase db = dbHelper.getWritableDatabase();
String whereClause = "age < ?";
String[] whereArgs = {"20"};
int rowsDeleted = db.delete(TABLE_NAME, whereClause, whereArgs); 使用事务保证数据一致性
在执行多个关联操作时,建议使用事务确保数据一致性,转账操作需要同时更新两个账户的余额,若中途失败则需回滚:

SQLiteDatabase db = dbHelper.getWritableDatabase();
db.beginTransaction();
try {
// 执行操作1
db.execSQL("UPDATE accounts SET balance = balance - 100 WHERE name = 'A'");
// 执行操作2
db.execSQL("UPDATE accounts SET balance = balance + 100 WHERE name = 'B'");
db.setTransactionSuccessful(); // 标记事务成功
} finally {
db.endTransaction(); // 结束事务,若未标记成功则自动回滚
} 最佳实践
- 避免SQL注入:使用
query()或rawQuery()的selectionArgs参数拼接SQL条件,而非直接拼接SQL语句。 - 关闭资源:及时关闭
Cursor和SQLiteDatabase,避免内存泄漏。 - 异步操作:数据库操作可能阻塞UI线程,建议使用
AsyncTask、Executor或Room库在后台执行。 - 使用ORM框架:对于复杂应用,可考虑
Room、GreenDAO等ORM框架,简化数据库操作并减少错误。
相关问答FAQs
Q1: 如何在Android中检查数据库是否创建成功?
A1: 可以通过文件管理器或ADB工具查看应用私有目录下的数据库文件,在SQLiteOpenHelper的onCreate()方法中添加日志输出(如Log.d("Database", "Database created")),或通过SQLiteDatabase的getPath()方法获取数据库文件路径并打印日志。
Q2: SQLite数据库是否支持多线程操作?
A2: SQLite数据库本身支持多线程读取,但写入操作是线程不安全的,若多个线程同时写入,可能导致数据库损坏,建议在多线程环境中使用SQLiteDatabase的beginTransaction()方法开启事务,或通过同步机制(如synchronized)保证同一时间只有一个线程执行写入操作。
【版权声明】:本站所有内容均来自网络,若无意侵犯到您的权利,请及时与我们联系将尽快删除相关内容!
发表回复