Android应用程序更新的时候如果数据库修改了字段需要更新数据库,并且保留原来的数据库数据:

这是原有的数据库表

CREATE_BOOK = "create table book(bookId integer primarykey,bookName text);";

然后我们增加一个字段:

CREATE_BOOK = "create table book(bookId integer primarykey,bookName text,bookContent text);";

首先我们需要把原来的数据库表重命名一下

CREATE_TEMP_BOOK = "alter table book rename to _temp_book";

然后把备份表中的数据copy到新创建的数据库表中

INSERT_DATA = "insert into book select *,' ' from _temp_book";(注意' '是为新加的字段插入默认值的必须加上,否则就会出错)。

然后我们把备份表干掉就行啦。

DROP_BOOK = "drop table _temp_book";

然后把数据库的版本后修改一下,再次创建数据库操作对象的时候就会自动更新(注:更新的时候第一个创建的操作数据的对象必须是可写的,也就是通过这个方法getWritableDatabase()获取的数据库操作对象)

然后在onUpgrade()方法中执行上述sql语句就OK了

public class DBservice extends SQLiteOpenHelper{
private String CREATE_BOOK = "create table book(bookId integer primarykey,bookName text);";
private String CREATE_TEMP_BOOK = "alter table book rename to _temp_book";
private String INSERT_DATA = "insert into book select *,'' from _temp_book";
private String DROP_BOOK = "drop table _temp_book";
public DBservice(Context context, String name, CursorFactory factory,int version) {
super(context, name, factory, version);
}

@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_BOOK);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
switch (newVersion) {
case 2:
db.execSQL(CREATE_TEMP_BOOK);
db.execSQL(CREATE_BOOK);
db.execSQL(INSERT_DATA);
db.execSQL(DROP_BOOK);
break;
}
}

更多相关文章

  1. Android系统源码数据库(mmssms.db)中几个表之间的关系.
  2. Android实现数据存储5种技术
  3. Android中数据库SQLite存储的基础知识
  4. Android两个android两个activity之间相互传递数据
  5. Android中传递对象的三种方法的实现
  6. Android图形---OpenGL(一)
  7. Android——Fragment A点击一个按钮跳转到 FragmentB
  8. Android(安卓)Hawk数据库 github开源项目
  9. Android(安卓)文件存储知识点总结

随机推荐

  1. Android面试题集锦
  2. Android中Touch事件的传递机制
  3. Android call setting 源码分析 从顶层到
  4. Android 开机图片/文字/动画的修改
  5. Android实现远程服务端与客户端的通信AID
  6. 获取 Android(安卓)设备的唯一标识码
  7. Android UIAutomator 定位方式详解
  8. Android Studio中创建Selector文件的方法
  9. Android之——自定义复合控件的实现
  10. android,不让edittext一进入页面就获取焦