快速的解决升级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"];//删除旧表
    }
}
视图:

恩,到这里完成更新操作了!!!!
posted @ 2016-04-07 16:47  御龙家园  阅读(3011)  评论(0编辑  收藏  举报