我在我的所有应用程序中使用SQLiteOpenHelper(如下所示)非常愉快。对现有数据库的大量升级在多年内取得了成功。
这次我需要在我的一个应用程序中升级数据库,此步骤将持续一段时间。所以我需要将这些升级语句放在自己的线程中。
最好的地方是什么?
非常感谢任何帮助。
public class MySQLiteOpenHelper extends SQLiteOpenHelper {
protected static final Object lock = new Object();
private static final int DATABASE_NAME = "mydatabase.db";
private static final int DATABASE_VERSION = 3;
private Context context;
private SQLiteDatabase database;
public MySQLiteOpenHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
this.context = context;
}
@Override
public void onCreate(SQLiteDatabase database) {
synchronized (lock) {
this.database = database;
// Create database statements
}
}
@Override
public void onUpgrade(SQLiteDatabase database, int oldVersion, int newVersion) {
synchronized (lock) {
this.database = database;
switch (newVersion) {
case DATABASE_VERSION:
switch (oldVersion) {
case 1:
upgradeFrom1To2();
case 2:
upgradeFrom2To3();
}
break;
}
}
}
private void upgradeFrom1To2() {
// Upgrade database statements
}
private void upgradeFrom2To3() {
// Upgrade database statements
}
}
答案 0 :(得分:0)
我将代码放在IntentService中,这是一种为长时间运行的操作实现后台线程的简单方法,尤其是保存数据的操作。如果需要,使用广播Intent将状态从IntentService发送到其他组件,使用BroadcastReceiver接收这些Intent。
我真的会避免在Activity中的AsyncTask中这样做;操作被杀死的风险太大。无论如何,AsyncTask比IntentService复杂得多。
一个注意事项:IntentService不会保留任何内容,包括其类字段。为了保护自己,您可能希望在SharedPreferences中存储状态。