首页 / ANDROID / Android 数据库升级
Android 数据库升级
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Android 数据库升级,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2704字,纯文字阅读大概需要4分钟。
内容图文
数据库升级: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;privatestaticfinalint DATABASE_VERSION = 1001;
//private static final int DATABASE_VERSION = 1002;privatestaticfinal String DATABASE_NAME = "mall.db";
privatestatic 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);
}
//创建对象(单例模式)publicsynchronized DbHelper getInstance(Context context) {
if (instance == null) {
instance = new DbHelper(context);
}
return instance;
}
//建表 @Override
publicvoid onCreate(SQLiteDatabase sqLiteDatabase) {
sqLiteDatabase.execSQL(SQL.CREATE_TABLE_fAVORATE);
// 若不是第一个版本安装,直接执行数据库升级
// 请不要修改FIRST_DATABASE_VERSION的值,其为第一个数据库版本大小finalint FIRST_DATABASE_VERSION = 1000;
onUpgrade(sqLiteDatabase, FIRST_DATABASE_VERSION, DATABASE_VERSION);
}
@Override
publicvoid 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;
}
}
}
privatevoid upgradeToVersion1001(SQLiteDatabase db) {
// favorite表新增1个字段
String sql1 = "ALTER TABLE " + SQL.T_FAVORITE + " ADD COLUMN deleted VARCHAR";
db.execSQL(sql1);
}
privatevoid 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"; publicstaticfinal String CREATE_TABLE_fAVORATE="create table T_FAVORITE if not exists" + "(_id integer primary key autoincrement," + "title varchar,url varchar," + "creataDate varchar)"; }
原文:http://www.cnblogs.com/zcp0118/p/7373069.html
内容总结
以上是互联网集市为您收集整理的Android 数据库升级全部内容,希望文章能够帮你解决Android 数据库升级所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。