App升級(jí)時(shí)數(shù)據(jù)庫(kù)的遷移更新

前一段時(shí)間在進(jìn)行App升級(jí)的時(shí)候,由于一開(kāi)始版本初期沒(méi)有考慮完善,導(dǎo)致走了很多彎路,后來(lái)經(jīng)過(guò)自己的一些思考,總結(jié)出了一些在app升級(jí)的時(shí)候,數(shù)據(jù)庫(kù)內(nèi)文件同步保持更新的經(jīng)驗(yàn),希望能給大家?guī)?lái)幫助.

總體方案及思路

流程圖

  1. 在每一次運(yùn)行程序的時(shí)候,判斷是否存在數(shù)據(jù)庫(kù),如果不存在則直接創(chuàng)建數(shù)據(jù)庫(kù),若存在取出數(shù)據(jù)庫(kù)版本號(hào)進(jìn)行其他的處理.

  2. ,當(dāng)用戶第一次下載安裝app的時(shí)候,第一次建立版本庫(kù),將我們的數(shù)據(jù)信息存入數(shù)據(jù)庫(kù)中,同時(shí)保存一個(gè)當(dāng)前版本號(hào)加一的字段到數(shù)據(jù)庫(kù)中.
    那么問(wèn)題來(lái)了,為什么我們需要將版本信息加一呢,這是為了以后進(jìn)行版本判斷的時(shí)候更加方便.
    還有一個(gè)問(wèn)題,為什么我們將版本信息放入數(shù)據(jù)庫(kù)而不使用UserDefaults快速存儲(chǔ)呢?原因是你需要考慮到
    當(dāng)你的app有不同的用戶登錄時(shí),UserDefaults是所有數(shù)據(jù)共享的,你不能根據(jù)不同的用戶來(lái)處理他的信息
    判段他的信息是否需要更新

  3. 當(dāng)用戶更新app的時(shí)候,會(huì)直接從數(shù)據(jù)庫(kù)中取出上一次保存的版本字段,例如是2.0版本的時(shí)候,會(huì)直接從case2開(kāi)始執(zhí)行,修改完數(shù)據(jù)結(jié)構(gòu)以后,再一次將版本字段存到數(shù)據(jù)庫(kù)中.

  4. 所以每更新一次版本,如果數(shù)據(jù)結(jié)構(gòu)信息有變動(dòng)的時(shí)候,直接在后面加case語(yǔ)句即可.

下面是一些參考代碼,使用FMDB庫(kù):


/**
 *  1.當(dāng)沒(méi)有數(shù)據(jù)庫(kù)存在的時(shí)候,創(chuàng)建數(shù)據(jù)庫(kù) 然后執(zhí)行版本1的創(chuàng)建(創(chuàng)建版本表,創(chuàng)建信息表),保存1.0+1.0信息到版本庫(kù),數(shù)據(jù)庫(kù)內(nèi)版本號(hào)為2.0
    2.當(dāng)有數(shù)據(jù)庫(kù)存在的時(shí)候,執(zhí)行判斷版本庫(kù)的版本信息,版本號(hào)賦值給dbVersion,然后進(jìn)行信息的更新,同時(shí)更新版本號(hào)的更新
 */
-(instancetype)init
{
    //設(shè)置數(shù)據(jù)庫(kù)版本為1
    int dbVersion = 1;
    if (self = [super init]) {
        //判斷本地有沒(méi)有數(shù)據(jù)庫(kù)文件
        if (![self isExistDB]) {
            //不存在 初始化數(shù)據(jù)庫(kù)
            [self createDB];
        }else
        {
            //如果存在,那么獲取版本信息
            _dataBase = [[FMDatabase alloc] initWithPath:[self getDBPath]];
            NSString * currentVersion = [self getDBInfoValue];
            dbVersion = currentVersion.intValue;
        }
        
        switch (dbVersion) {   //判斷版本信息
            case 1:
            {
                //說(shuō)明用戶第一次安裝  1.0版本
                //創(chuàng)建版本表
                [self excuteLocalSql:createTB_info];
                //創(chuàng)建信息表
                [self excuteLocalSql:create_tusersql];
                //保存1.0+1.0信息到數(shù)據(jù)庫(kù)   用于下一次判斷版本號(hào)
                [self setDBInfoValueWithString:@"2.0"];
            }
            case 2:
            {
                //更新信息表
                [self excuteLocalSql:update_tusersql];
                //保存2.0+1.0到數(shù)據(jù)庫(kù)
                [self setDBInfoValueWithString:@"3.0"];
            }
                case 3:
                [self excuteLocalSql:modify];
                [self setDBInfoValueWithString:@"4.0"];
            default:
                break;
        }
        
    }
    return self;
}```

使用的方法:

//使用的SQL語(yǔ)句
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'";

//判斷是否存在數(shù)據(jù)庫(kù)
-(BOOL)isExistDB
{
NSFileManager *fileManager = [NSFileManager defaultManager];
return [fileManager fileExistsAtPath:[self getDBPath]];
}

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

pragma mark - 更新版本號(hào)

-(BOOL)updateVersionInfoWithString:(NSString *)version
{
NSString *sql = @"UPDATE t_info SET version = ?";
BOOL b = [_dataBase executeUpdate:sql,version];
return b;
}

pragma mark - 插入版本號(hào)

-(BOOL)insertVersionInfoWithString:(NSString *)version
{
NSString *sql = @"INSERT INTO t_info(version) VALUES(?)";
BOOL b = [_dataBase executeUpdate:sql,version];
return b;
}

pragma mark - 創(chuàng)建版本信息

  • (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";
    //注意 需要先打開(kāi)數(shù)據(jù)庫(kù)
    [_dataBase open];
    FMResultSet *resultSet = [_dataBase executeQuery:sql];

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

pragma mark - 創(chuàng)建數(shù)據(jù)庫(kù)中的表

  • (BOOL)excuteLocalSql:(NSString *)createTB_info
    {
    BOOL b = [_dataBase executeUpdate:createTB_info];
    NSLog(@"表的創(chuàng)建結(jié)果:%d",b);
    return b;
    }

pragma mark - 初始化數(shù)據(jù)庫(kù)

  • (void)createDB
    {
    _dataBase = [[FMDatabase alloc] initWithPath:[self getDBPath]];
    if (_dataBase.open == YES) {
    NSLog(@"數(shù)據(jù)庫(kù)成功創(chuàng)建!");
    }else
    {
    NSLog(@"創(chuàng)建失敗!");
    }
    }```

如果覺(jué)得對(duì)自己有幫助的話,請(qǐng)點(diǎn)贊噢!
有什么疑問(wèn)和問(wèn)題可以直接私信我.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末刻帚,一起剝皮案震驚了整個(gè)濱河市康二,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖芹扭,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異炫乓,居然都是意外死亡膏燕,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門屹蚊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)厕氨,“玉大人,你說(shuō)我怎么就攤上這事淑翼「玻” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵玄括,是天一觀的道長(zhǎng)冯丙。 經(jīng)常有香客問(wèn)我,道長(zhǎng)遭京,這世上最難降的妖魔是什么胃惜? 我笑而不...
    開(kāi)封第一講書人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮哪雕,結(jié)果婚禮上船殉,老公的妹妹穿的比我還像新娘。我一直安慰自己斯嚎,他們只是感情好利虫,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著堡僻,像睡著了一般糠惫。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上钉疫,一...
    開(kāi)封第一講書人閱讀 51,631評(píng)論 1 305
  • 那天硼讽,我揣著相機(jī)與錄音,去河邊找鬼牲阁。 笑死固阁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的城菊。 我是一名探鬼主播备燃,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼凌唬!你這毒婦竟也來(lái)了并齐?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎冀膝,沒(méi)想到半個(gè)月后唁奢,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡窝剖,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年麻掸,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赐纱。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡脊奋,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出疙描,到底是詐尸還是另有隱情诚隙,我是刑警寧澤,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布起胰,位于F島的核電站久又,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏效五。R本人自食惡果不足惜地消,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望畏妖。 院中可真熱鬧脉执,春花似錦、人聲如沸戒劫。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)迅细。三九已至巫橄,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間疯攒,已是汗流浹背嗦随。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工列荔, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留敬尺,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓贴浙,卻偏偏與公主長(zhǎng)得像砂吞,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子崎溃,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容