Sqlite 版本升级设计 第二版

/**
 * @author liulp
 */
public class MySqlite extends SQLiteOpenHelper {

    private volatile SQLiteDatabase db;

    //建表语句 此部分只是用户第一次安装的时候会在oncreate方法中调用 
    //请注意CREATE部分不要做任何修改 所有的数据库修改都应该在 update_sql中进行
    String CREATE[] = new String[] { "create table " + TB_USER + " (tid  integer primary key,name varchar(50));",
	    "Create table " + TB_USER_REPORT + "( tid integer primary key,uid integer , score integer);", };

    //升级部分的
    private static UpDateGrades[] updategrades = new UpDateGrades[] {

    new UpDateGrades() {

	@Override
	public void doupDateGrade(SQLiteDatabase db) {
	    // TODO Auto-generated method stub
	    db.execSQL("create table " + TB_USER_REPORT + " (tid  integer primary key,uid interger,score interger);");
	}
    },

    };

    private static final String DBNAME = "popo";

    //
    public static final String TB_USER = "user";
    public static final String TB_USER_REPORT = "user_report";

    String TAG = "SQLITE";

    private static volatile MySqlite mySqlite = null;

    private MySqlite(Context context) {

	super(context, DBNAME, null, updategrades.length + 1);
	Log.v("MySqlite", " version=" + updategrades.length + 1);
	db = getWritableDatabase();
	updategrades = null;
	CREATE = null;

    }

    public static MySqlite instance(Context context) {
	if (mySqlite == null) {
	    synchronized (MySqlite.class) {
		if (mySqlite == null)
		    mySqlite = new MySqlite(context);
	    }
	}

	return mySqlite;
    }

    public SQLiteDatabase getSQLiteDatabase() {
	if (db == null) {
	    synchronized (this) {
		if (db == null)
		    db = getWritableDatabase();
	    }

	} else {
	    if (db.isOpen() == false) {
		synchronized (this) {
		    if (db.isOpen() == false) {
			db = null;
			db = getWritableDatabase();
		    }
		}
	    }
	}
	return db;

    }

    /**
     * 执行创建 数据库语句
     */
    @Override
    public void onCreate(SQLiteDatabase db) {
	// TODO Auto-generated method stub
	Log.v(TAG, "MyDBHelper onCreate");
	for (String sql : CREATE) {
	    db.execSQL(sql);
	}
    }
    
    //执行升级语句 
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
	// TODO Auto-generated method stub
	Log.v(" Version", "oldVersion=" + oldVersion + ",newVersion=" + newVersion);
	for (int i = oldVersion; i < newVersion; i++) {
	    updategrades[i - 1].doupDateGrade(db);
	}
    }
    
    //升级语句接口
    interface UpDateGrades {
	void doupDateGrade(SQLiteDatabase db);
    };

}


主要修改时把升级操作改成了一个借口方法,这样可以实现更复杂的需求分析,并且多个修改语句可以在一个方法中执行,版本号可以和我们发布的App版本比较更贴近。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值