需要在一个线程中升级SQLite,如何以及在哪里?

时间:2012-11-20 13:21:05

标签: android sqlite

我在我的所有应用程序中使用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
    }
}

1 个答案:

答案 0 :(得分:0)

我将代码放在IntentService中,这是一种为长时间运行的操作实现后台线程的简单方法,尤其是保存数据的操作。如果需要,使用广播Intent将状态从IntentService发送到其他组件,使用BroadcastReceiver接收这些Intent。

我真的会避免在Activity中的AsyncTask中这样做;操作被杀死的风险太大。无论如何,AsyncTask比IntentService复杂得多。

一个注意事项:IntentService不会保留任何内容,包括其类字段。为了保护自己,您可能希望在SharedPreferences中存储状态。