【Android 数据库升级】亦余心之所善兮,虽九死其犹未悔。这篇文章主要讲述Android 数据库升级相关的知识,希望能为你提供帮助。
数据库升级:v1.0-v2.1
从v1.0升级到v2.01,不走oncreate,走onupdategrade
直接安装v2.0,走onCreate;
v1.0-v3.0:分三种情况
1.v1.0升级到v3.0: 不走onCreate,走onUpgrade
2.v2.0升级到v3.0:不走onCreate,走onUpgrade
3.直接安装v3.0:走onCreate,不走onUpgrade
public class DbHelper extends SQLiteOpenHelper { // private static final int DATABASE_VERSION = 1000; private static final int DATABASE_VERSION = 1001; //private static final int DATABASE_VERSION = 1002; private static final String DATABASE_NAME = "mall.db"; private static DbHelper instance = null; /*操作数据库有两个非常重要的类:SQLiteDatabase和SQLiteOpenHelper * 1.SQLiteDatabase的实例便代表了SQLite数据库,通过SQLiteDatabase的一些常用方法,可以执行SQL语句, * 对数据库进行添加、删除、更新、查找和修改等操作
* 2.SQLiteOpenHelper是一个辅助类,主要负责创建和打开数据库以及对数据库的版本进行管理。 * SQLiteOpenHelper是一个抽象类,需要继承它并实现它的几个回调函数 * */ /* 1.写内部类 继承SQLiteOpenHelper 2.生成实现方法 (1)创建public void onCreate(SQLiteDatabase db) { (2)升级public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 3.生成器 调用父类的构造方法 public DBHelper(String name, int version) {4.点击事件 调用构造方法DBHelper 创建 连接数据库 *///内部类继承需要自己生成构造器 public DbHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); }//创建对象(单例模式) public synchronized DbHelper getInstance(Context context) { if (instance == null) { instance = new DbHelper(context); } return instance; }//建表 @Override public void onCreate(SQLiteDatabase sqLiteDatabase) { sqLiteDatabase.execSQL(SQL.CREATE_TABLE_fAVORATE); // 若不是第一个版本安装,直接执行数据库升级 // 请不要修改FIRST_DATABASE_VERSION的值,其为第一个数据库版本大小 final int FIRST_DATABASE_VERSION = 1000; onUpgrade(sqLiteDatabase, FIRST_DATABASE_VERSION, DATABASE_VERSION); }@Override public void onUpgrade(SQLiteDatabase sqLiteDatabase, int oldVersion, int newVersion) { // 使用for实现跨版本升级数据库 for (int i = oldVersion; i < newVersion; i++) { switch (i) { case 1000: //从v1.0升级到v1.1 upgradeToVersion1001(sqLiteDatabase); break; case 1001: //从v1.1升级到v1.2 upgradeToVersion1002(sqLiteDatabase); break; default: break; } }}private void upgradeToVersion1001(SQLiteDatabase db) { // favorite表新增1个字段 String sql1 = "ALTER TABLE " + SQL.T_FAVORITE + " ADD COLUMN deleted VARCHAR"; db.execSQL(sql1); }private void upgradeToVersion1002(SQLiteDatabase db) { // favorite表新增2个字段,添加新字段只能一个字段一个字段加,sqlite有限制不予许一条语句加多个字段 String sql1 = "ALTER TABLE " + SQL.T_FAVORITE + " ADD COLUMN message VARCHAR"; String sql2 = "ALTER TABLE " + SQL.T_FAVORITE + " ADD COLUMN type VARCHAR"; db.execSQL(sql1); db.execSQL(sql2); } }
//创建数据库(建表)
public class SQL { public static final String T_FAVORITE = "favorite"; public static final String CREATE_TABLE_fAVORATE="create table T_FAVORITE if not exists" + "(_id integer primary key autoincrement," + "title varchar,url varchar," + "creataDate varchar)"; }
推荐阅读
- mybatis 整合spring之mapperLocations配置的问题
- MacOS Sierra10.12.4编译Android7.1.1源代码必须跳的坑
- 安卓6.0编译遇到的问题
- Citrix XenApp/XenDesktop 7.15 LTSR发布
- android studio 开发经常使用快捷键使用分享
- android ndk
- cordova platform add android报错问题处理
- Android雷达图(蜘蛛网图)
- android viewStub