我正在努力更好地理解SQLiteOpenHelper类以及如何以及何时调用onCreate和onUpgrade。
我的问题是,每次我退出并启动我的应用程序(从技术上讲,实际上每次我创建一个新的MyDB实例),都会调用onCreate,并且有效地擦除了之前用法中的所有数据... WTF ???
我最初通过创建单个MyDBFactory解决了这个问题,我在其中创建了一个MyDB实例。这使得数据在应用程序运行时至少具有持久性。
我想要的是我的数据库架构和数据是持久的!
我基本上有:
public class MyDB extends SQLiteOpenHelper{
private static int VERSION = 1;
...
public ContactControlDB(Context context) {
super(context, null, null, VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
try {
db.execSQL(DATABASE_CREATE);
db.execSQL(INSERT_DATA);
} catch (SQLException ex) {
ex.printStackTrace();
}
}
和:
public class MyDBFactory{
private static MyDB db;
public static MyDB getInstance(Context context) {
if(db == null) {
db = new MyDB (context);
}
return db;
}
}
我想知道的是为什么每次我有'新MyDB(上下文)'时调用onCreate,以及每次我的应用程序退出时我的数据库都会被调用。
如果你有一些适当的链接,或者某些知识可以让我知道一点,我会非常感激!
答案 0 :(得分:7)