微信數(shù)據(jù)庫(kù)WCDB的基本使用與高級(jí)接口使用-iOS

WCDB簡(jiǎn)介

WCDB 是騰訊開(kāi)源的移動(dòng)數(shù)據(jù)庫(kù)框架倡怎,官網(wǎng):https://github.com/Tencent/wcdb踢械。和fmdb相比,主要是它支持ORM绽诚,用c++編寫的典徊,效率更高并且還是跨平臺(tái)的,既可以在iOS上使用也可以在Android上使用恩够。

基本使用的步驟

使用Cocoapods 安裝卒落,pod ‘WCDB’,其他安裝方式請(qǐng)參考https://github.com/Tencent/wcdb/wiki

1蜂桶、創(chuàng)建數(shù)據(jù)庫(kù)

- (WCTDatabase *)database {

? ? static WCTDatabase *db = nil;

? ? static dispatch_once_t onceToken;

? ? dispatch_once(&onceToken, ^{

? ? ? ? NSString *docDir = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) firstObject];

? ? ? ? db = [[WCTDatabase alloc] initWithPath:[docDir stringByAppendingPathComponent:@"my_db"]];

? ? ? ? if ([db canOpen]) {

? ? ? ? ? ? [db createTableAndIndexesOfName:@"user" withClass:[DBModel class]];

? ? ? ? ? ? //如果表不存在就創(chuàng)建表儡毕,如果字段有更新,就更新表扑媚,所以不用判斷是否已經(jīng)存在該表

? ? ? ? }

? ? });

? ? _database = db;

? ? return _database;

}


2腰湾、新增數(shù)據(jù)

DBModel *model = [[DBModel alloc] init];

? model.isAutoIncrement = YES; // 如果你的模型里使用了WCDB_PRIMARY_AUTO_INCREMENT,就要把該屬性設(shè)置為YES疆股,否則會(huì)報(bào)錯(cuò)

? ? model.age = age;

? ? model.name = name;

? ? if ([self.database insertObject:model into:@"user"]) {

? ? ? ? [_dataArray addObject:model];

? ? }


3檐盟、刪除數(shù)據(jù),其中user_id被定義為自增的主鍵

[self.database deleteObjectsFromTable:@"user" where:DBModel.user_id.is(model.user_id)]


4押桃、修改數(shù)據(jù)

model.age = age;

? model.name = name;

? ?if ([self.database updateAllRowsInTable:@"user" onProperties:{DBModel.age ,DBModel.name} withObject:model]) {

? ? ? ? ? ? NSLog(@"修改成功");

? ? ? ? }


5葵萎、查詢數(shù)據(jù)

[self.database getAllObjectsOfClass:DBModel.class fromTable:@"user"];//查詢所有

[self.database getOneObjectOfClass:DBModel.class fromTable:@"user" where:DBModel.user_id.is(1)];//按條件查詢


6、高級(jí)api介紹

?//getAllObjectsOnResults表示只查詢某幾個(gè)字段的值唱凯,但是返回的對(duì)象還是模型數(shù)組

? ? NSArray? *names= [self.database getAllObjectsOnResults:{DBModel.name} fromTable:@"user"];

? ? //getOneRowOnResults返回的是該屬性的值的數(shù)組

? ? WCTOneRow *oneRow=? [self.database getOneRowOnResults:{DBModel.name} fromTable:@"user"];

? ? //AnyProperty.count()?查詢表的數(shù)據(jù)條數(shù)

? ? id?count=? [self.database getOneValueOnResult:DBModel.AnyProperty.count() fromTable:@"user"];

? ? //getOneObjectOfClass羡忘,返回表中的第一個(gè)模型對(duì)象

? ? id?obj =? [self.database getOneObjectOfClass:DBModel.class fromTable:@"user"];

? ? //getAllRowsOnResults返回二維數(shù)組,其中每個(gè)數(shù)組的對(duì)象包含的是每個(gè)字段的值

? ? WCTColumnsXRows *row =? [self.database getAllRowsOnResults:{DBModel.name,DBModel.age} fromTable:@"user"];


模型的定義

模型需遵循WCTTableCoding協(xié)議

@interface DBModel : NSObject <WCTTableCoding>

@property int user_id;

@property (nonatomic, strong) NSString *name;

@property (nonatomic, assign) NSInteger age;

WCDB_PROPERTY(user_id)

WCDB_PROPERTY(name)

WCDB_PROPERTY(age)

@end

@implementation DBModel WCDB_IMPLEMENTATION(DBModel) WCDB_SYNTHESIZE(DBModel, name) WCDB_SYNTHESIZE(DBModel, age) WCDB_SYNTHESIZE(DBModel, user_id) WCDB_PRIMARY_AUTO_INCREMENT(DBModel, user_id)

使用起來(lái)覺(jué)得挺方便的磕昼!比f(wàn)mdb優(yōu)雅卷雕。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市票从,隨后出現(xiàn)的幾起案子漫雕,更是在濱河造成了極大的恐慌,老刑警劉巖峰鄙,帶你破解...
    沈念sama閱讀 211,123評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件浸间,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡吟榴,警方通過(guò)查閱死者的電腦和手機(jī)魁蒜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人兜看,你說(shuō)我怎么就攤上這事锥咸。” “怎么了细移?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,723評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵搏予,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我弧轧,道長(zhǎng)缔刹,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,357評(píng)論 1 283
  • 正文 為了忘掉前任劣针,我火速辦了婚禮校镐,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘捺典。我一直安慰自己鸟廓,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布襟己。 她就那樣靜靜地躺著引谜,像睡著了一般。 火紅的嫁衣襯著肌膚如雪擎浴。 梳的紋絲不亂的頭發(fā)上员咽,一...
    開(kāi)封第一講書(shū)人閱讀 49,760評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音贮预,去河邊找鬼贝室。 笑死,一個(gè)胖子當(dāng)著我的面吹牛仿吞,可吹牛的內(nèi)容都是我干的滑频。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼唤冈,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼峡迷!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起你虹,我...
    開(kāi)封第一講書(shū)人閱讀 37,672評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤绘搞,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后傅物,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體夯辖,經(jīng)...
    沈念sama閱讀 44,118評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評(píng)論 2 325
  • 正文 我和宋清朗相戀三年挟伙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了楼雹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片模孩。...
    茶點(diǎn)故事閱讀 38,599評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡尖阔,死狀恐怖贮缅,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情介却,我是刑警寧澤谴供,帶...
    沈念sama閱讀 34,264評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站齿坷,受9級(jí)特大地震影響桂肌,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜永淌,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評(píng)論 3 312
  • 文/蒙蒙 一崎场、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧遂蛀,春花似錦谭跨、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,731評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至所坯,卻和暖如春谆扎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背芹助。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,956評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工堂湖, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人状土。 一個(gè)月前我還...
    沈念sama閱讀 46,286評(píng)論 2 360
  • 正文 我出身青樓苗缩,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親声诸。 傳聞我的和親對(duì)象是個(gè)殘疾皇子酱讶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評(píng)論 2 348