是因为在Android中,每个数据库都是由一个SQLiteOpenHelper对象管理的。SQLiteOpenHelper是一个帮助类,用于管理数据库的创建和版本控制。它提供了一个getWritableDatabase()方法来获取一个可写的数据库对象,以及一个getReadableDatabase()方法来获取一个可读的数据库对象。
在Android中,每个SQLiteOpenHelper对象只能管理一个数据库文件,也就是说每个SQLiteOpenHelper对象只能打开一个数据库。如果想要操作多个表,可以在同一个数据库文件中创建多个表,并使用相应的SQL语句进行操作。
以下是一个示例代码,演示如何在Android中创建多个表的数据库:
public class MyDatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "my_database.db";
private static final int DATABASE_VERSION = 1;
// 构造方法
public MyDatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
// 创建数据库
@Override
public void onCreate(SQLiteDatabase db) {
// 创建表1
String createTable1 = "CREATE TABLE table1 (id INTEGER PRIMARY KEY, name TEXT)";
db.execSQL(createTable1);
// 创建表2
String createTable2 = "CREATE TABLE table2 (id INTEGER PRIMARY KEY, age INTEGER)";
db.execSQL(createTable2);
}
// 升级数据库
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// 删除旧表
db.execSQL("DROP TABLE IF EXISTS table1");
db.execSQL("DROP TABLE IF EXISTS table2");
// 创建新表
onCreate(db);
}
}
在上述代码中,我们创建了一个名为"my_database.db"的数据库文件,并在该数据库中创建了两个表:table1和table2。可以根据实际需求修改表的结构和字段。
使用该数据库的示例代码如下:
// 创建数据库对象
MyDatabaseHelper dbHelper = new MyDatabaseHelper(context);
// 获取可写的数据库对象
SQLiteDatabase db = dbHelper.getWritableDatabase();
// 执行SQL语句,操作表1
db.execSQL("INSERT INTO table1 (id, name) VALUES (1, 'John')");
db.execSQL("UPDATE table1 SET name = 'Tom' WHERE id = 1");
db.execSQL("DELETE FROM table1 WHERE id = 1");
// 执行SQL语句,操作表2
db.execSQL("INSERT INTO table2 (id, age) VALUES (1, 20)");
db.execSQL("UPDATE table2 SET age = 30 WHERE id = 1");
db.execSQL("DELETE FROM table2 WHERE id = 1");
// 关闭数据库连接
db.close();
在上述代码中,我们通过MyDatabaseHelper类创建了一个数据库对象,并获取了可写的数据库对象。然后,我们可以使用db.execSQL()方法执行SQL语句,对表1和表2进行插入、更新和删除操作。
需要注意的是,为了保证数据库的一致性和安全性,应该在操作完数据库后调用db.close()方法关闭数据库连接。
领取专属 10元无门槛券
手把手带您无忧上云