App升级时数据库的迁移更新

前一段时间在进行App升级的时候,由于一开始版本初期没有考虑完善,导致走了很多弯路,后来经过自己的一些思考,总结出了一些在app升级的时候,数据库内文件同步保持更新的经验,希望能给大家带来帮助.

总体方案及思路

流程图

  1. 在每一次运行程序的时候,判断是否存在数据库,如果不存在则直接创建数据库,若存在取出数据库版本号进行其他的处理.
  2. ,当用户第一次下载安装app的时候,第一次建立版本库,将我们的数据信息存入数据库中,同时保存一个当前版本号加一的字段到数据库中.
     那么问题来了,为什么我们需要将版本信息加一呢,这是为了以后进行版本判断的时候更加方便.
     还有一个问题,为什么我们将版本信息放入数据库而不使用UserDefaults快速存储呢?原因是你需要考虑到
     当你的app有不同的用户登录时,UserDefaults是所有数据共享的,你不能根据不同的用户来处理他的信息
     判段他的信息是否需要更新
  3. 当用户更新app的时候,会直接从数据库中取出上一次保存的版本字段,例如是2.0版本的时候,会直接从case2开始执行,修改完数据结构以后,再一次将版本字段存到数据库中.
  4. 所以每更新一次版本,如果数据结构信息有变动的时候,直接在后面加case语句即可.

下面是一些参考代码,使用FMDB库:

/**
 *  1.当没有数据库存在的时候,创建数据库 然后执行版本1的创建(创建版本表,创建信息表),保存1.0+1.0信息到版本库,数据库内版本号为2.0
    2.当有数据库存在的时候,执行判断版本库的版本信息,版本号赋值给dbVersion,然后进行信息的更新,同时更新版本号的更新
 */
-(instancetype)init
{
    //设置数据库版本为1
    int dbVersion = 1;
    if (self = [super init]) {
        //判断本地有没有数据库文件
        if (![self isExistDB]) {
            //不存在 初始化数据库
            [self createDB];
        }else
        {
            //如果存在,那么获取版本信息
            _dataBase = [[FMDatabase alloc] initWithPath:[self getDBPath]];
            NSString * currentVersion = [self getDBInfoValue];
            dbVersion = currentVersion.intValue;
        }

        switch (dbVersion) {   //判断版本信息
            case 1:
            {
                //说明用户第一次安装  1.0版本
                //创建版本表
                [self excuteLocalSql:createTB_info];
                //创建信息表
                [self excuteLocalSql:create_tusersql];
                //保存1.0+1.0信息到数据库   用于下一次判断版本号
                [self setDBInfoValueWithString:@"2.0"];
            }
            case 2:
            {
                //更新信息表
                [self excuteLocalSql:update_tusersql];
                //保存2.0+1.0到数据库
                [self setDBInfoValueWithString:@"3.0"];
            }
                case 3:
                [self excuteLocalSql:modify];
                [self setDBInfoValueWithString:@"4.0"];
            default:
                break;
        }

    }
    return self;
}

使用的方法:

//使用的SQL语句
static  NSString *createTB_info=@"create table if not exists t_info (version text)";
static  NSString *create_tusersql = @"CREATE TABLE IF NOT EXISTS T_User (userid INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, username TEXT, usergender TEXT, usercreatetime date, userupdatetime date,age INTEGER,islogined INTEGER)";
static  NSString * update_tusersql = @"alter table T_User  add  column useraddress TEXT";
static  NSString *modify=@"alter table T_User add column password text not null default ‘111111‘";

//判断是否存在数据库
-(BOOL)isExistDB
{
    NSFileManager *fileManager = [NSFileManager defaultManager];
    return [fileManager fileExistsAtPath:[self getDBPath]];
}

//得到路径
-(NSString *)getDBPath
{
    return [NSString stringWithFormat:@"%@/Documents/user1.sqlite",NSHomeDirectory()];
}

#pragma mark - 更新版本号
-(BOOL)updateVersionInfoWithString:(NSString *)version
{
    NSString *sql = @"UPDATE t_info SET version = ?";
    BOOL b = [_dataBase executeUpdate:sql,version];
    return b;
}

#pragma mark - 插入版本号
-(BOOL)insertVersionInfoWithString:(NSString *)version
{
    NSString *sql = @"INSERT INTO t_info(version) VALUES(?)";
    BOOL b = [_dataBase executeUpdate:sql,version];
    return b;
}

#pragma mark - 创建版本信息
- (BOOL)setDBInfoValueWithString:(NSString *)string
{
    if ([self getDBInfoValue]) {
        //更新版本
        [self updateVersionInfoWithString:string];
    }
    else
    {
        //插入版本
        [self insertVersionInfoWithString:string];
    }
    return YES;
}

//得到版本信息
- (NSString *)getDBInfoValue
{
    NSString *sql = @"select version from t_info";
    //注意   需要先打开数据库
    [_dataBase open];
    FMResultSet *resultSet = [_dataBase executeQuery:sql];

    NSString * version = nil;
    while ([resultSet next]) {
        version = [resultSet stringForColumn:@"version"];
    }
    return version;
}

#pragma mark - 创建数据库中的表
- (BOOL)excuteLocalSql:(NSString *)createTB_info
{
    BOOL b = [_dataBase executeUpdate:createTB_info];
    NSLog(@"表的创建结果:%d",b);
    return b;
}

#pragma mark - 初始化数据库
- (void)createDB
{
    _dataBase = [[FMDatabase alloc] initWithPath:[self getDBPath]];
    if (_dataBase.open == YES) {
        NSLog(@"数据库成功创建!");
    }else
    {
        NSLog(@"创建失败!");
    }
}
时间: 2025-01-01 10:05:43

App升级时数据库的迁移更新的相关文章

C# 使用Code First迁移更新数据库

三步完成迁移: 1. 启用迁移: Enable-Migrations Enable-Migrations -ContextTypeName Mvc4WebSite.Models.MvcGuestbookContext 迁移 Mvc4WebSite项目下的MvcGuestbookContext.迁移成功提示:已为项目 Mvc4WebSite 启用 Code First 迁移. 2. 添加迁移: Add-Migration Add-Migration InitialCreate 3. 将迁移更新到数

System.InvalidOperationException: 支持“XXX”上下文的模型已在数据库创建后发生更改。请考虑使用 Code First 迁移更新数据库(http://go.microsoft.com/fwlink/?LinkId=238269)。

System.InvalidOperationException: 支持"XXX"上下文的模型已在数据库创建后发生更改.请考虑使用 Code First 迁移更新数据库(http://go.microsoft.com/fwlink/?LinkId=238269). EF发布时遇到的问题(数据库初始化 http://www.cr173.com/html/17941_1.html) public ZujuanWebSiteDataEntities() : base("cloud_

基于现有数据库的Code First模式迁移更新数据库

本文讨论的内容是基于EF4.1版本.文中谈论的现有的数据库不是由EF创建.本文假定你已经对Code First迁移有一定的了解,如果不了解Code First迁移更新数据库可以查看 文章涉及的主题如下: 1.创建模型 2.可迁移性 3.添加一个初始迁移 a.使用现有的schema作为起点 b.以一个空数据库作为起点 4.注意点: a.默认的/计算的名称可能与现有schema不匹配 b.不是所有的数据库对象都在model中表现出来 一.创建模型 第一步是创建一个以现有数据库为目标的Code Fir

支持“***Context”上下文的模型已在数据库创建后发生更改。请考虑使用 Code First 迁移更新数据库(http://go.microsoft.com/fwlink/?LinkId=238269)。

在用VS进行MVC开发的过程中遇到如下问题: 支持“***Context”上下文的模型已在数据库创建后发生更改.请考虑使用 Code First 迁移更新数据库(http://go.microsoft.com/fwlink/?LinkId=238269). 解决了,把数据库中检测模型变化的表(如上图所示)删除就可以了

"支持“xxx”上下文的模型已在数据库创建后发生更改。请考虑使用 Code First 迁移更新数据库”解决办法

学习Asp.Net MVC4 时,使用EF.本来正常,但是由于修改了一下Model中的一个实体类. 导致这个错误. “支持“xxx”上下文的模型已在数据库创建后发生更改.请考虑使用 Code First 迁移更新数据库”. 为了解决上述错误,在Global.asax文件中在 Application_Start后添加以下语句: Database.SetInitializer(new DropCreateDatabaseIfModelChanges<SalesERPDAL>()); 注意需引入命名

flask数据库的迁移

如果是单纯的用flask去启动app.run()是没有办法想django那样对数据库进行迁移的 首先要安装 pip install flask-migrate 然后修改代码,改变flask的启动方式 from flask_migrate import Migrate,MigrateCommand from flask_script import Shell,Manager ... manager = Manager(app) #第一个参数是Flask的实例,第二个参数是Sqlalchemy数据库

从model到数据库的迁移(转载)

先附上原文链接:http://www.cnblogs.com/babykick/archive/2012/02/02/2336019.html 1)创建一个没有数据库的新项目时 1.创建数据库 2.将south添加到INSTALLED_APPS 3.运行syncdb命令,它将django和south的数据表加入到数据库中 4.将你创建的apps添加到INSTALLED_APPS 5.对每个app分别运行"python manage.py schemamigration app_name --in

oracle数据库的迁移(从一台服务器到另一个台服务器,从oracle 10g到oracle 11g)

这个过程呢,还是蛮艰难的.... 一.最初我使用的是Navicat中的数据传输来迁移的,虽说整个数据库的迁移没有成功,但传输指定的对象时还是传输成功了.所以还是记录一下吧. 1.前提连接好数据库.在指定的数据库上右击,选择"数据传输". 2.在弹出的框内选择源库和目的库以及模式和你要传输的对象,如下图所示 3.点击开始便可传输 二.在利用Navicat只可传输对象,没办法传输模式等.但是如果要迁移整个数据库,肯定不仅只有迁移对象这么简单了.于是我选择了expdp和impdp导入导出的方

开源一个适用iOS的数据库表结构更新机制的代码

将前段时间开源的代码,发布一下: ARDBConfig On the iOS, provide a database table structure update mechanism, ensure that the user in any version of the installer, the database structure to ensure adapter. (在iOS上,提供一个数据库表结构更新的机制,保证用户无论从哪个版本安装程序,数据库结构保证适配.) 如:用户A的数据库版