文档章节

Android SQLite数据库升级方案

yizhichao
 yizhichao
发布于 2017/01/13 12:43
字数 300
阅读 36
收藏 0

例如一个数据库表

19版本是2个字段
20版本是3个字段
21版本是4个字段

 

 

package com.yzc.atclient.service.db;

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

import com.allcam.atclient.app.ClientApplication;

public class DatabaseHelper extends SQLiteOpenHelper
{
    private static final String DB_NAME = "allcam_db";

    private static final int VERSION = 1;

    private static volatile DatabaseHelper instance;

    public DatabaseHelper(Context context)
    {
        this(context, DB_NAME, null, VERSION);
    }

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

    public static DatabaseHelper getInstance()
    {
        if (null == instance)
        {
            synchronized (DatabaseHelper.class)
            {
                if (null == instance)
                {
                    instance = new DatabaseHelper(ClientApplication.getAppContext());
                }
            }
        }
        return instance;
    }

    @Override
    public void onCreate(SQLiteDatabase db)
    {
        CardUserTable.createTable(db);
        TaskStatusTable.createTable(db);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
    {
          //在这里组合case 判断 升级
    }
}

 

例如:


for (int j = oldVersion; j <= newVersion; j++) {

            switch (j) {

            case 2:

          //创建临时表

                db.execSQL(TEMP_SQL_CREATE_TABLE_SUBSCRIBE);

          //执行OnCreate方法,这个方法中放的是表的初始化操作工作,比如创建新表之类的

                onCreate(db);

          //删除之前的表里面的那4条默认的数据

                for (int i = 0; i < arrWhereAct.length; i++) {

                    db.execSQL(DELETE_TEMP_SUBSCRIBE + arrWhereAct[i]);

                }

               //将临时表中的数据放入表A 

         Cursor cursor = db.rawQuery(INSERT_SUBSCRIBE, null);

                if (cursor.moveToFirst()) {

                    do {

                        db.execSQL(cursor.getString(cursor

                                .getColumnIndex("insertSQL")));

                    } while (cursor.moveToNext());

                }

                cursor.close();

          //将临时表删除掉

                db.execSQL(DROP_TEMP_SUBSCRIBE);



                break;



            default:

                break;

            }

        }


 

© 著作权归作者所有

yizhichao

yizhichao

粉丝 16
博文 468
码字总数 363983
作品 0
南京
程序员
私信 提问
Database (SQLite)--数据库(SQLite)

一、SQLite简介 SQLite 的网站 (sqlite.org) 对SQL进行了如下描述:“SQLite 是一个可实现独立、无服务器、零配置、事务性 SQL 数据库引擎的软件库”。这句话中的关键要素都围绕着“库”这一...

失足处男的倒霉孩子
2013/12/27
1K
0
Android 开发中使用 SQLite 数据库

SQLite 介绍 SQLite 一个非常流行的嵌入式数据库,它支持 SQL 语言,并且只利用很少的内存就有很好的性能。此外它还是开源的,任何人都可以使用它。许多开源项目((Mozilla, PHP, Python)都...

红薯
2010/08/22
67.6K
32
手机开发-如何查看android数据文件和数据库

在Android中可以使用Eclipse插件DDMS来查看,也可以使用Android工具包中的adb工具来查看。android项目中的sqlite数据库位于/data/data/项目包/databases中。 工具/原料 doc命令adb工具,ecl...

娶到笨笨
2014/03/14
380
0
Android SMS(二)—— 读取短信保存到 SQLite

Android 之 SMS 短信在Android系统中是保存在SQLite数据库中的,但不让其它程序访问(Android系统的安全机制) 现在我们在读取手机内的SMS短信,先保存在我们自己定义的SQLite数据库中,然后...

长平狐
2013/01/06
425
0
安卓应用安全指南 4.5.3 使用 SQLite 高级话题

安卓应用安全指南 4.5.3 使用 SQLite 高级话题 原书:Android Application Secure Design/Secure Coding Guidebook 译者:飞龙 协议:CC BY-NC-SA 4.0 4.5.3.1 在 SQL 语句的断言中使用通配符...

apachecn_飞龙
2018/03/22
0
0

没有更多内容

加载失败,请刷新页面

加载更多

面试官,Java8 JVM内存结构变了,永久代到元空间

在文章《JVM之内存结构详解》中我们描述了Java7以前的JVM内存结构,但在Java8和以后版本中JVM的内存结构慢慢发生了变化。作为面试官如果你还不知道,那么面试过程中是不是有些露怯?作为面试...

程序新视界
27分钟前
15
0
读书笔记:深入理解ES6 (八)

第八章 迭代器(Iterator)与生成器(Generator) 第1节 循环语句的问题   在循环、多重循环中,通过变量来跟踪数组索引的行为容易导致程序出错。迭代器的出现旨在消除这种复杂性,并减少循...

张森ZS
27分钟前
13
0
Elasticsearch 实战(一) - 简介

官腔 Elasticsearch,分布式,高性能,高可用,可伸缩的搜索和分析系统 基本等于没说,咱们慢慢看 1 概述 百度:我们比如说想找寻任何的信息的时候,就会上百度去搜索一下,比如说找一部自己喜...

JavaEdge
32分钟前
13
0
【jQuery基础学习】11 jQuery性能简单优化

本文转载于:专业的前端网站➦【jQuery基础学习】11 jQuery性能简单优化 关于性能优化 合适的选择器 $("#id")会直接调用底层方法,所以这是最快的。如果这样不能直接找到,也可以用find方法继...

前端老手
40分钟前
12
0
重磅发布 | 全球首个云原生应用标准定义与架构模型 OAM 正式开源

导读:2019 年 10 月 17 日,阿里巴巴合伙人、阿里云智能基础产品事业部总经理蒋江伟(花名:小邪)在 Qcon 上海重磅宣布,阿里云与微软联合推出开放应用模型 Open Application Model (OAM...

阿里云官方博客
43分钟前
15
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部