我必须在我的 android 应用程序中创建近 5-6 个表。创建 SQLite 数据库和 5-6 个表的最佳位置是什么?我可以在初始活动启动时编写所有这些逻辑(使用 SQLite 开放辅助方法),但如果我这样做,它将在每次初始活动启动时被调用。这意味着每次应用程序启动时都会执行这些数据库和表的创建逻辑。任何人都可以告诉最佳实践来做到这一点。
4 回答
如果您编写一个类来扩展 SQLiteOpenHelper 并在 onCreate 方法中创建您的表,它将只执行一次。仅当您从设备中完全删除数据/应用程序时,助手才会重新创建数据。
来自developer.android.com:第一次创建数据库时调用。这是表的创建和表的初始填充应该发生的地方。
给你一些更多的信息。在用于扩展 SQLiteOpenHelper 的类的构造函数中,调用超级构造函数,它接受一些参数。其中之一是数据库版本。
如果传递给超级构造函数的这个 db_version 与最后传递的不同,则调用 onUpgrade 方法,在 onUpgrade() 方法中可以调用 onCreate()
所以:
- 删除数据/应用
- 导致调用 onUpgrade 调用 onCreate()
是创建/更新/删除数据库的方法
您可以在主要活动中创建数据库和表
但在创建数据库之前,您可以检查
if(exits())
{
// do not create
}
else
{
// create here
}
Personnaly,我使用选项 : CREATE TABLE IF NOT EXISTS
。
所以打开的助手有这个参数:
private static final int VERSION_BDD = 1;
我认为 openHelper 不会在每次启动时重新创建每个表。
您可以使用扩展 SQLiteOpenHelper 的内部类并覆盖方法 public void onCreate(SqLiteDatabase sqlLiteDatabase) 和 public void onUpgrade(SQLiteDatabase sqLiteDatabase, int oldVersion, int newVersion)
当磁盘中不存在数据库并且辅助类需要创建一个新数据库时调用 onCreate
当数据库版本不匹配时调用 onUpgrade。磁盘上的db版本需要升级到newVersion
private static final class PatientDatabaseHelper extends SQLiteOpenHelper {
private static final String TAG = "PatientProvider";
private static final String DATABASE_NAME = "myPatient.db";
private static final int DATABASE_VERSION = 1;
private static final String PATIENT_TABLE = "PATIENT";
private static final String CREATE_TABLE_PATIENT =
"create table " + PATIENT_TABLE + " ("
+ PATIENT_KEY_ID + " integer primary key autoincrement, "
+ PATIENT_NAME + " TEXT NOT NULL, "
+ PATIENT_FIRST_NAME + " TEXT NOT NULL, "
+ PATIENT_TEL + " TEXT, "
+ PATIENT_GSM1 + " TEXT, "
+ PATIENT_GSM2 + " TEXT, "
+ PATIENT_BIRTHDATE + " DATE); ";
public PatientDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
sqLiteDatabase.execSQL(CREATE_TABLE_PATIENT);
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int oldVersion, int newVersion) {
Log.w(TAG, "Upgrading database from version " + oldVersion + " to "
+ newVersion + ", which will destroy all old data");
//simple case sample - droppin the table
sqLiteDatabase.execSQL("DROP TABLE IF IT EXISTS " + PATIENT_TABLE);
//Create a new One
onCreate(sqLiteDatabase);
}
}
取决于 android 的目标版本,但我认为一个好的方法是使用 ContentProvider http://developer.android.com/guide/topics/providers/content-provider-creating.html