Android SQLite数据库版本升级的管理实现

Android SQLite数据库版本升级的管理实现

我们知道在SQLiteOpenHelper的构造方法:

super(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) 

中最后一个参数表示数据库的版本号.当新的版本号大于当前的version时会调用方法:

onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) 

所以我们的重点是在该方法中实现SQLite数据库版本升级的管理

当我们项目刚开始的时候第一版SQLiteOpenHelper是这样写的:

package cc.database; 

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
/**
 * Demo描述:
 * SQLite数据库版本升级的管理实现
 *
 * 参考资料:
 * http://blog.csdn.net/guolin_blog
 * Thank you very much
 */
public class DataBaseOpenHelper extends SQLiteOpenHelper {
  private final static String DATABASE_NAME="test.db";
  private static DataBaseOpenHelper mDataBaseOpenHelper; 

  public static final String CREATE_PERSON=
  "create table person(personid integer primary key autoincrement,name varchar(20),phone VARCHAR(12))"; 

  public DataBaseOpenHelper(Context context,String name,CursorFactory factory,int version) {
    super(context, name, factory, version);
  } 

  //注意:
  //将DataBaseOpenHelper写成单例的.
  //否则当在一个for循环中频繁调用openHelper.getWritableDatabase()时
  //会报错,提示数据库没有执行关闭操作
  static synchronized DataBaseOpenHelper getDBInstance(Context context) {
    if (mDataBaseOpenHelper == null) {
      mDataBaseOpenHelper = new DataBaseOpenHelper(context,DATABASE_NAME,null,1);
    }
    return mDataBaseOpenHelper;
  }  

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

  @Override
  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 

  } 

}

在几天之后根据项目需求,需要添加一张student表,于是DataBaseOpenHelper就出现了第二版:

package cc.database; 

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper; 

public class DataBaseOpenHelper extends SQLiteOpenHelper {
  private final static String DATABASE_NAME="test.db";
  private static DataBaseOpenHelper mDataBaseOpenHelper; 

  public static final String CREATE_PERSON=
  "create table person(personid integer primary key autoincrement,name varchar(20),phone VARCHAR(12))"; 

  public static final String CREATE_STUDENT=
  "create table student(studentid integer primary key autoincrement,name varchar(20),phone VARCHAR(12))"; 

  public DataBaseOpenHelper(Context context,String name,CursorFactory factory,int version) {
    super(context, name, factory, version);
  } 

  //注意:
  //将DataBaseOpenHelper写成单例的.
  //否则当在一个for循环中频繁调用openHelper.getWritableDatabase()时
  //会报错,提示数据库没有执行关闭操作
  static synchronized DataBaseOpenHelper getDBInstance(Context context) {
    if (mDataBaseOpenHelper == null) {
      //改动1
      mDataBaseOpenHelper = new DataBaseOpenHelper(context,DATABASE_NAME,null,2);
    }
    return mDataBaseOpenHelper;
  }  

  @Override
  public void onCreate(SQLiteDatabase db) {
    db.execSQL(CREATE_PERSON);
    //改动2
    db.execSQL(CREATE_STUDENT);
  } 

  @Override
  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    //改动3
    switch (oldVersion) { 

    case 1:
    db.execSQL(CREATE_STUDENT); 

    default:
    }
  } 

}

较版本一在版本二中有三处修改的地方:

1 版本号变成了2

2 在onCreate()方法中添加了代码db.execSQL(CREATE_STUDENT);创建student表

因为有的用户根本就没有第一版本的APP,直接从市场下载了第二版本的App。所以当然会执行onCreate()而不会执行onUpgrade()

3 在onUpgrade()做了处理:当oldVersion为1时调用db.execSQL(CREATE_STUDENT);创建student表
   因为有的用户手机上本来就有第一版本的APP,所以在App升级到第二版本时会执行onUpgrade(),不会执行onCreate()

通过这样的处理使得不同的情况下使用第二版APP时都会生成student表

又过了一个月,根据项目变更,需要给person表添加一个字段genderid,于是DataBaseOpenHelper就出现了第三版:

package cc.database; 

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper; 

public class DataBaseOpenHelper extends SQLiteOpenHelper {
  private final static String DATABASE_NAME="test.db";
  private static DataBaseOpenHelper mDataBaseOpenHelper; 

  //改动1
  public static final String CREATE_PERSON=
  "create table person(personid integer primary key autoincrement,name varchar(20),phone VARCHAR(12)),genderid integer)"; 

  public static final String ALTER_PERSON="alter table person add column genderid integer"; 

  public static final String CREATE_STUDENT=
  "create table student(studentid integer primary key autoincrement,name varchar(20),phone VARCHAR(12))"; 

  public DataBaseOpenHelper(Context context,String name,CursorFactory factory,int version) {
    super(context, name, factory, version);
  } 

  //注意:
  //将DataBaseOpenHelper写成单例的.
  //否则当在一个for循环中频繁调用openHelper.getWritableDatabase()时
  //会报错,提示数据库没有执行关闭操作
  static synchronized DataBaseOpenHelper getDBInstance(Context context) {
    if (mDataBaseOpenHelper == null) {
      //改动2
      mDataBaseOpenHelper = new DataBaseOpenHelper(context,DATABASE_NAME,null,3);
    }
    return mDataBaseOpenHelper;
  }  

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

  @Override
  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    switch (oldVersion) { 

    case 1:
    db.execSQL(CREATE_STUDENT); 

    //改动3
    case 2:
    db.execSQL(ALTER_PERSON); 

    default:
    }
  } 

}

较版本二在版本三中有三处修改的地方:

1 改变了CREATE_PERSON语句,在改语句中增加了一个字段genderid

和前面的描述类似,有的用户第一次安装该APP时就直接下载了第三版

2 修改版本号为3

应对了用户从第一版本或者第二版本升级到第三版本的情况(见下分析)

3 在onUpgrade()方法中)做了处理:当oldVersion为2时调用 db.execSQL(ALTER_PERSON);修改person表,增加genderid字段

应对了用户从第二版本升级到第三版本的情况(见下分析)

注意一个问题:为什么这里的switch语句在每个case中没有break???

这是为了保证跨版本升级的时候每次数据库的升级都会执行到。

比如从第二版升级到第三版本,那么case 2会被执行。

比如从第一版直接升级到第三版本,那么case 1肯定会被调用,由于没有break所以会穿透switch语句又执行case 2语句继续升级,从而保证了数据的所有版本中的升级都会被执行到。

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

(0)

相关推荐

  • Android中操作SQLite数据库快速入门教程

    SQLite是Android平台软件开发中会经常用到的数据库产品,作为一款轻型数据库,SQLite的设计目标就是是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够.下面我们一起来看看针对Android平台的SQlite 3的使用. 以下概念都是在Android平台的SQlite限制下的理解: 数据库基础概念 1.SQlite 通过文件来保存数据库,一个文件就是一个数据库. 2.数据库里又包含数个表格: 3.每个表格里面包含了多个记录

  • Android 数据库打包随APK发布的实例代码

    其实很简单,就是把我们的数据库文件放到我们的手机里,所以不必局限在哪个地方写这个代码,在第一次创建数据库的时候可以,我觉得在软件起动页里效果更好一点,首先我们应该把事先写好的数据库文件比如 test.db放到res文件夹里的raw文件夹里,也可以放到assets里,因为这两个文件夹不会在生成APK的时候不会被压缩. 1,DataBaseUtil用于将raw中的db文件copy到手机中,代码如下 复制代码 代码如下: import java.io.File;import java.io.FileO

  • 条件数据库Android:sqllite的简单使用

    SQLite分析 SQLite是轻量级的.嵌入式的.关系型数据库,现在已经在iPhone.Android等手机系统中应用,SQLite可移植性好,很轻易应用,很小,高效而且牢靠.SQLite嵌入到应用它的应用程序中,它们共用雷同的进程空间,而不是单独的一个进程.从外部看,它并不像一个RDBMS,但在进程内部,它倒是完整的,自包括的数据库引擎. 在android中当须要操作SQLite数据库的时候须要失掉一个SQLiteOpenHelper对象,而SQLiteOpenHelper是一个抽象类,用户

  • Android SQLite数据库增删改查操作的使用详解

    一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字). TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型只有五种,但实际上sqlite3也接受varchar(n). char(n).decimal(p,s) 等数据类型,只不过在运算或保存时会转成对应的五种数据类型. SQLite最大的特点是你可以把各种类型的数据保存到任何字段中,而不用关心字段

  • Android实现创建或升级数据库时执行语句

    本文实例讲述了Android创建或升级数据库时执行的语句,如果是创建或升级数据库,请使用带List参数的构造方法,带SQL语句的构造方法将在数据库创建或升级时执行. 具体程序代码如下: import java.util.List; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFac

  • Android创建和使用数据库SQLIte

    一.关系型数据库SQLIte         每个应用程序都要使用数据,Android应用程序也不例外,Android使用开源的.与操作系统无关的SQL数据库-SQLite.SQLite第一个Alpha版本诞生于2000年5月,它是一款轻量级数据库,它的设计目标是嵌入式的,占用资源非常的低,只需要几百K的内存就够了.SQLite已经被多种软件和产品使用,Mozilla FireFox就是使用SQLite来存储配置数据的,Android和iPhone都是使用SQLite来存储数据的. SQLite

  • Android SQLite数据库增删改查操作的案例分析

    Person实体类 复制代码 代码如下: package com.ljq.domain; public class Person {    private Integer id;    private String name;    private String phone; public Person() {        super();    } public Person(String name, String phone) {        super();        this.n

  • Android操作SQLite数据库(增、删、改、查、分页等)及ListView显示数据的方法详解

    本文实例讲述了Android操作SQLite数据库(增.删.改.查.分页等)及ListView显示数据的方法.分享给大家供大家参考,具体如下: 由于刚接触android开发,故此想把学到的基础知识记录一下,以备查询,故此写的比较啰嗦: 步骤如下: 一.介绍: 此文主要是介绍怎么使用android自带的数据库SQLite,以及把后台的数据用ListView控件显示 二.新建一个android工程--DBSQLiteOperate 工程目录: 三.清单列表AndroidManifest.xml的配置

  • Android使用SQLite数据库的简单实例

    先画个图,了解下Android下数据库操作的简单流程: 1.首先,写一个自己的数据库操作帮助类,这个类继承自Android自带的SQLiteOpenHelper. 2.在自己的DAO层借助自己的Helper写数据库操作的一些方法 3.Activity调用DAO层的数据库操作方法进行操作 下面例子是: 1.Helper 复制代码 代码如下: package cn.learn.db.util; import android.content.Context;import android.databas

  • Android开发中数据库升级且表添加新列的方法

    本文实例讲述了Android开发中数据库升级且表添加新列的方法.分享给大家供大家参考,具体如下: 今天突然想到我们android版本升级的时候经常会遇到升级版本的时候在新版本中数据库可能会修改,今天我们就以数据库升级且表添加新列为例子写一个测试程序. 首先在要创建一个数据库,一般我们先创建一个DbHelper,继承SQLiteOpenHelper,构造函数我们使用传递版本号的: public DbHelper(Context context, String name, int version){

随机推荐