SqliteOpenHelper的onUpgrade()死活不运行的解法

自己的机器 android 2.3,刷的小米系统,曾经执行成功过一次,前后传的版本号也正确,后来死活不执行,确实是调用的getWritableDatabase(),看了Android源码,也没发现异常。

百思不得其解!换了公司的一台测试机,又可以。

由此暂时断定这个onUpgrade不靠谱,自己写了一套升级sqlite数据库的逻辑。

在assets下做一个update.sql文件,然后读取文件,一行行的执行sql;若升级成功,在库里面写个标记。

注意:update.sql里面,一个完整的操作,其包含的句子需要合并成一行。

代码如下(只是思路,不可直接copy使用):

    private void updateDB() {
        SqliteHelper sqliteHelper = SqliteHelper.getInstance(this);
        if (!("" + Config.SQLITE_DB_VERSION)
                .equals(sqliteHelper.getValue(Configuration.DB_VERSION))) {
            LogUtil.i(TAG, "=====数据库升级开始=====");
            // sqliteHelper.beginTransaction();
            try {
                InputStream in = this.getAssets().open("update.sql");
                BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(in));
                String tmpStr = null;
                StringBuffer sql = new StringBuffer();
                while ((tmpStr = bufferedReader.readLine()) != null) {
                    sql.append(tmpStr);
                    sql.append("\n");
                    if (tmpStr.trim().endsWith(";")) {
                        sqliteHelper.execSQL(sql.toString());
                        sql = new StringBuffer();
                    }
                }
                bufferedReader.close();
                in.close();
                // sqliteHelper.setTransactionSuccessful();
                sqliteHelper.setValue(Configuration.DB_VERSION, "" + Config.SQLITE_DB_VERSION);
                LogUtil.i(TAG, "=====数据库升级成功!=====");
            } catch (Exception e) {
                LogUtil.e(TAG, e.getMessage());
            } finally {
                // sqliteHelper.endTransaction();
            }
        }
    }

 

posted @ 2013-02-25 16:41  Kai.Ma  阅读(3679)  评论(0编辑  收藏  举报