IOS開發(fā)中APP直接與數(shù)據(jù)庫交互

前言

  • 最近一個月是考試月和答辯月碳想,時間很少,博客有兩周沒更新了毁靶。會在近期補上胧奔,請諒解。
  • 信息系統(tǒng)開發(fā)中预吆,APP這一塊涉及到了和數(shù)據(jù)庫的交互龙填。但是小組人員都沒有會后臺的,所以我們就決定不適用后臺來讓應(yīng)用直接和數(shù)據(jù)庫連接。PS:應(yīng)用和數(shù)據(jù)庫直接通訊是不推薦的哦~
  • IOS APP直接和數(shù)據(jù)庫連接比較麻煩岩遗,如果使用的是SQLite還好扇商,只需要加入libsqlite3.0.tbd依賴以及引入sqlite3.h頭文件即可。但是使用MySQL宿礁,則就比較麻煩案铺。我使用的是一個第三方庫OHMySQL

安裝第三方庫OHMySQL

安裝第三方庫可以直接去github上面下載下來拖入工程中,也可以使用cocoaPods來方便快速的導(dǎo)入第三方庫梆靖。我使用的是cocoaPods控汉,不會使用的同學(xué)自己谷歌一下,挺簡單的返吻。

  • 在IOS工程中新建一個podfile文件姑子,輸入以下內(nèi)容:
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '8.0'

target '你的項目名字' do

pod 'OHMySQL'

end
  • 新建好podfile文件后,在終端中輸入:
Larry:ConnToSQL Larry$ pod install
  • 看到下圖的綠色文字后思喊,代表導(dǎo)入成功壁酬。
導(dǎo)入第三方庫成功提示

使用OHMySQL

  • 安裝好第三方庫后,運行你的項目.xcworkspace恨课。
  • 使用這個庫的大致流程如下:

1.初始化數(shù)據(jù)庫用戶
2.初始化連接器
3.連接到數(shù)據(jù)庫
4.設(shè)置設(shè)備上下文數(shù)據(jù)
5.數(shù)據(jù)交互

    // 初始化數(shù)據(jù)庫連接用戶
    OHMySQLUser *usr = [[OHMySQLUser alloc] initWithUserName:@"itimes" password:@"iTimessql" serverName:@"114.215.103.67" dbName:@"itimes" port:3306 socket:nil];
    // 初始化連接器
    OHMySQLStoreCoordinator *coordinator = [[OHMySQLStoreCoordinator alloc] initWithUser:usr];
    // 連接到數(shù)據(jù)庫
    [coordinator connect];
    // 初始化設(shè)備上下文
    OHMySQLQueryContext *queryContext = [OHMySQLQueryContext new];
    // 設(shè)置連接器
    queryContext.storeCoordinator = coordinator;
    // 獲取log表中的數(shù)據(jù)
    OHMySQLQueryRequest *query = [OHMySQLQueryRequestFactory SELECT:@"log" condition:nil];
    NSError *error = nil;
    // task用于存放數(shù)據(jù)庫返回的數(shù)據(jù)
    NSArray *tasks = [queryContext executeQueryRequestAndFetchResult:query error:&error];
    if (tasks != nil) {
        NSLog(@"%@",tasks);
    }

數(shù)據(jù)庫操作對應(yīng)語法

  • 查找
OHMySQLQueryRequest *query = [OHMySQLQueryRequestFactory SELECT:@"tasks" condition:nil];
NSError *error = nil;
NSArray *tasks = [queryContext executeQueryRequestAndFetchResult:query error:&error];
  • 插入
OHMySQLQueryRequest *query = [OHMySQLQueryRequestFactory INSERT:@"tasks" set:@{ @"name": @"Something", @"desctiption": @"new task" }];
NSError error;
[queryContext executeQueryRequest:query error:&error];
  • 刪除
OHMySQLQueryRequest *query = [OHMySQLQueryRequestFactory DELETE:@"tasks" condition:@"id=10"];
  • 連接,連接有4種(INNER, RIGHT, LEFT, FULL)
OHMySQLQueryRequest *query = [OHMySQLQueryRequestFactory JOINType:OHJoinInner
                                                        fromTable:@"tasks"
                                                      columnNames:@[@"id", @"name", @"description"]
                                                           joinOn:@{ @"subtasks":@"tasks.id=subtasks.parentId" }];
NSArray *results = [queryContext executeQueryRequestAndFetchResult:query error:nil];
  • 具體內(nèi)容請參見:OHMySQL

注意事項

  • 查找操作中的condition代表篩選操作舆乔,對應(yīng)對sql中的WHERE XXX AND XXX,但是,where是不需要自己加入的剂公,我們看源碼可知希俩,作者會自動加入WHERE。比如我想查找task表中id = 10,名字為larry的字段纲辽,需要這樣輸入:
OHMySQLQueryRequest *query = [OHMySQLQueryRequestFactory SELECT:@"tasks" condition:@"id = ‘10 and name = ’larry‘’"];

最后

  • 演示一下我一個自己查詢數(shù)據(jù)庫的操作(只有DEBUG打友瘴洹):
與數(shù)據(jù)庫通訊測試
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市拖吼,隨后出現(xiàn)的幾起案子鳞上,更是在濱河造成了極大的恐慌,老刑警劉巖吊档,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件篙议,死亡現(xiàn)場離奇詭異,居然都是意外死亡怠硼,警方通過查閱死者的電腦和手機鬼贱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來香璃,“玉大人这难,你說我怎么就攤上這事∑厦耄” “怎么了姻乓?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵嵌溢,是天一觀的道長。 經(jīng)常有香客問我糖权,道長堵腹,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任星澳,我火速辦了婚禮疚顷,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘禁偎。我一直安慰自己腿堤,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布如暖。 她就那樣靜靜地躺著笆檀,像睡著了一般。 火紅的嫁衣襯著肌膚如雪盒至。 梳的紋絲不亂的頭發(fā)上酗洒,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天,我揣著相機與錄音枷遂,去河邊找鬼樱衷。 笑死,一個胖子當(dāng)著我的面吹牛酒唉,可吹牛的內(nèi)容都是我干的矩桂。 我是一名探鬼主播,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼痪伦,長吁一口氣:“原來是場噩夢啊……” “哼侄榴!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起网沾,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤癞蚕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后辉哥,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體桦山,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年证薇,在試婚紗的時候發(fā)現(xiàn)自己被綠了度苔。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片匆篓。...
    茶點故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡浑度,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出鸦概,到底是詐尸還是另有隱情箩张,我是刑警寧澤甩骏,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站先慷,受9級特大地震影響饮笛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜论熙,卻給世界環(huán)境...
    茶點故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一福青、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧脓诡,春花似錦无午、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至交惯,卻和暖如春次泽,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背席爽。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工意荤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人拳昌。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓袭异,卻偏偏與公主長得像,于是被迫代替她去往敵國和親炬藤。 傳聞我的和親對象是個殘疾皇子御铃,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,927評論 2 355

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