快速的解决升级app之后更新数据库的表结构

如果我们的app新版本要需要对某个表进行添加字段,更新app的时候我们也要对数据库进行更新,也同样需要添加新字段. 我的项目里,原来的

session表主键是 sessionId  ,但是由于项目需要,我们把主键换成了business_id   然后,原来的主键就变成普通字段了,更新数据库的时候,我们要怎么更新主键,和添加字段,并且复制原有数据库的数据呢???(哎,菜鸟一个,忙到凌晨2点多才搞定)

 项目里在哪里创的表,就在哪里进行结构的判断,以及做出相应的表更新(操作数据库用的是框架--FMDB)

旧项目我的表是这样创建的:

- (void)sessionTableCreate {
    [self createTable:@"session" sql:@"CREATE table session (sessionId TEXT NOT NULL PRIMARY KEY UNIQUE ON CONFLICT REPLACE, dateTime INTEGER,type INTEGER,text varchar(2048),unreadCount INTEGER,sumCount INTEGER,state INTEGER)"];
}

视图:

 

新版本主键换成 business_id   添加了新的字段   chat_session_type     visit_studio_id       (然后原来的主键就要变成普通的字段了)

@property (nonatomic, strong) FMDatabase *dataBase;

- (void)sessionTableCreate {
    [self createTable:@"session" sql:@"CREATE table session (business_id TEXT NOT NULL PRIMARY KEY UNIQUE ON CONFLICT REPLACE, sessionId TEXT NOT NULL, dateTime INTEGER,type INTEGER,text varchar(2048),unreadCount INTEGER,sumCount INTEGER,state INTEGER, chat_session_type TEXT, visit_studio_id TEXT)"];
    
    if (![self.dataBase columnExists:@"chat_session_type" inTableWithName:@"session"] && ![self.dataBase columnExists:@"visit_studio_id" inTableWithName:@"session"]) {//判断表是否包含某个字段
        
        [self.dataBase executeUpdate:@"ALTER TABLE session RENAME TO temp_session"];//将原来的表改名
        
        [self createTable:@"session" sql:@"CREATE table session (business_id TEXT NOT NULL PRIMARY KEY UNIQUE ON CONFLICT REPLACE, sessionId TEXT NOT NULL, dateTime INTEGER,type INTEGER,text varchar(2048),unreadCount INTEGER,sumCount INTEGER,state INTEGER, chat_session_type TEXT, visit_studio_id TEXT)"];//创建新表
        
        [self.dataBase executeUpdate:@"insert into session(business_id,sessionId,dateTime,type,text,unreadCount,sumCount,state,chat_session_type,visit_studio_id) select sessionId,sessionId,dateTime,type,text,unreadCount,sumCount,state,'','' from temp_session"];//复制改名后的表到新建的表(注意:一列对应一列的进行复制,新增的字段可以用''来补  因为我主键是NOT NULL 不能为空,所以我这里暂时先把原来的sessionId数据也复制到主键列)
        [self.dataBase executeUpdate:@"drop table temp_session"];//删除旧表
    }
}
视图:

恩,到这里完成更新操作了!!!!

转载于:https://www.cnblogs.com/yulongjiayuan/p/5364272.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值