日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

使用sqlite創(chuàng)建內(nèi)存數(shù)據(jù)

 禁忌石 2018-04-05
sqlite支持創(chuàng)建數(shù)據(jù)庫,如果建立多個(gè)鏈接鏈接該庫需要執(zhí)行ATTACH命令

//創(chuàng)建內(nèi)存數(shù)據(jù)庫 
sqlite3 *db;  
sqlite3 *tmp;  
 rc = sqlite3_open("new1.db", &db);
if( rc ){  
   fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));  
   return(0);  
}else{  
   fprintf(stderr, "Opened database successfully\n");  
  
/*執(zhí)行attach*/  
rc = sqlite3_open("new2.db", &tmp);  
rc = sqlite3_exec(tmp,"attach 'new.db' as newdb",0,0,&zErrMsg);     
if( rc != SQLITE_OK ){  
   fprintf(stderr, "SQL error: %s\n", zErrMsg);  
   sqlite3_free(zErrMsg);  
}    

兩個(gè)數(shù)據(jù)庫連接db和tmp,通過attach命令連接到new1.db,但是兩個(gè)連接有不同之處。new.db存在表select,使用db查詢時(shí)執(zhí)行如下sql

select * from test

tmp連接通過帶有模式的查詢sql

  select * from newdb.test

這樣兩個(gè)連接都可以操作new1.db了。

創(chuàng)建內(nèi)存數(shù)據(jù)庫需要數(shù)據(jù)文件名改成“:memory:”,注意前后都有要分號,要不不是內(nèi)存數(shù)據(jù),


//創(chuàng)建內(nèi)存數(shù)據(jù)庫  
rc = sqlite3_open(":memory:", &db);  
if( rc ){  
   fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));  
   return(0);  
}else{  
   fprintf(stderr, "Opened database successfully\n");  
}  

但是通過attach命令無法實(shí)現(xiàn)兩個(gè)鏈接共享一個(gè)內(nèi)存數(shù)據(jù)庫,實(shí)驗(yàn)證明attach后會(huì)新創(chuàng)建一個(gè)內(nèi)存數(shù)據(jù)庫,解決的辦法有兩個(gè):

1、將一部分內(nèi)存虛擬一個(gè)磁盤,SQLite的數(shù)據(jù)庫就放到這個(gè)虛擬磁盤中。

2、升級到最新版本的sqlite,支持多個(gè)鏈接共享內(nèi)存數(shù)據(jù)庫,詳細(xì)做法參考:

https://www./inmemorydb.html

    本站是提供個(gè)人知識管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多