IOS FMDB+SQL語句

轉(zhuǎn)載別人的文章

//聯(lián)系人:石虎QQ: 1224614774昵稱:嗡嘛呢叭咪哄

/**

注意點: 1.看 GIF 效果圖.

2.看連線視圖的效果圖.

3.看實現(xiàn)代碼(直接復(fù)制實現(xiàn)效果).

4.看實現(xiàn)代碼MVC架構(gòu)

*/

一、GIF 效果圖:

二、連線視圖的效果圖:

圖1:

圖2:

圖3:

三、實現(xiàn)代碼:

=======

================================

=======

1.AppDelegate.m 中的代碼

#import"AppDelegate.h"

#import"ViewController.h"http://主控制器

@interfaceAppDelegate()

@end

@implementationAppDelegate

- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions {

//初始化

ViewController*vc = [[ViewControlleralloc]init];

//導(dǎo)航控制器

UINavigationController*nvc = [[UINavigationControlleralloc]initWithRootViewController:vc];

//添加圖

self.window.rootViewController= nvc;

returnYES;

}

================================

=======

2.導(dǎo)入第三方數(shù)據(jù)庫 FMDB 框架包

下載地址:https://github.com/ccgus/fmdb

注意:要導(dǎo)入 libsqlite3.tbd 包 (詳情請看上面圖3)

================================

=======

3.在 Other 模塊中添加業(yè)務(wù)處理層處理 SQLite 語句

注意:如果現(xiàn)在拷貝到項目會報錯-->原因是其他 MVC 模塊中的類沒有實現(xiàn)

控制器1

.h:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import

#import"Model.h"

#import"FMDatabase.h"

@interfaceLoadData :NSObject

//單列類

+(instancetype)sharlLoadData;

//添加元素

-(void)AddsharlLoadData:(Model*)model;

//查詢

-(NSMutableArray*)Marr;

//刪除元素

-(void)deleteharlLoadData:(Model*)model;

//修改元素

-(void)UPsharlLoadData:(Model*)model;

@end

控制器1

.M:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import"LoadData.h"

staticLoadData*ld =nil;

staticFMDatabase*fate;

@implementationLoadData

//單列類

+(instancetype)sharlLoadData{

//靜態(tài)

staticdispatch_once_toneet;

//初始化

dispatch_once(&oneet, ^{

ld= [[LoadDataalloc]init];

//定義初始化

[ldinitA];

});

//返回值

returnld;

}

//初始化

+(instancetype)allocWithZone:(struct_NSZone*)zone{

if(!ld) {

//初始化

ld= [superallocWithZone:zone];

}

returnld;

}

//淺復(fù)制

-(id)copy{

returnself;

}

//深復(fù)制

-(id)mutableCopy{

returnself;

}

//初始化數(shù)據(jù)庫

-(void)initA{

//創(chuàng)建沙盒

NSString*Ste = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,

NSUserDomainMask,YES)objectAtIndex:0];

//定義文件名

NSString*path = [StestringByAppendingPathComponent:@"HousingInfo.sqlite"];

//初始化

fate= [[FMDatabasealloc]initWithPath:path];

//判斷

if([fateopen]) {

//初始化

[fateexecuteUpdate:@"create table class (ID integer primary

key, fieldMail text, fieldAddress text , fieldConsignee text , fieldPhone text , fieldNote text)"];

[fateclose];

NSLog(@"成功");

}else{

NSLog(@"失敗");

}

}

//添加元素

-(void)AddsharlLoadData:(Model*)model{

//開始

[fateopen];

//初始化

NSString*str = [NSStringstringWithFormat:@"insert

into class values (null , '%@','%@','%@','%@','%@')",model.fieldMail,model.fieldAddress,

model.fieldConsignee,model.fieldPhone,model.fieldNote];

//BOOL值接受

BOOLii = [fateexecuteUpdate:str];

//判斷

if(ii) {

NSLog(@"成功");

}else{

NSLog(@"失敗");

}

//關(guān)閉

[fateclose];

}

//查詢

-(NSMutableArray*)Marr{

//初始化

NSMutableArray*marr = [NSMutableArraynew];

//開始

[fateopen];

//初始化

FMResultSet*Set = [[FMResultSetalloc]init];

//使用set接受

Set = [fateexecuteQuery:@"select * from class"];

//判斷

while([Setnext]) {

//初始化

Model*mm = [Modelnew];

//鏈接

mm.fieldMail= [SetstringForColumn:@"fieldMail"];

mm.fieldAddress = [Set stringForColumn:@"fieldAddress"];

mm.fieldConsignee = [Set stringForColumn:@"fieldConsignee"];

mm.fieldPhone = [Set stringForColumn:@"fieldPhone"];

mm.fieldNote = [Set stringForColumn:@"fieldNote"];

mm.ID = [Set intForColumn:@"ID"];

//添加到數(shù)組

[marr addObject:mm];

}

//關(guān)閉

[fate close];

//返回值

returnmarr;

}

//刪除元素

-(void)deleteharlLoadData:(Model *)model{

//開始

[fate open];

//初始化

NSString *str = [NSString stringWithFormat:@"delete from class where ID = '%ld' ",model.ID];

//BOOL值接受

BOOLii = [fate executeUpdate:str];

//判斷

if(ii) {

NSLog(@"成功");

}else{

NSLog(@"失敗");

}

//關(guān)閉

[fate close];

}

//修改元素

-(void)UPsharlLoadData:(Model *)model{

//開始

[fate open];

//初始化

NSString *str = [NSString stringWithFormat:@"update

class set fieldMail = '%@',fieldAddress = '%@',fieldConsignee =

'%@',fieldPhone = '%@',fieldNote = '%@' where ID = '%ld'",model.fieldMail,model.fieldAddress,model.fieldConsignee,

model.fieldPhone,model.fieldNote,model.ID]

//BOOL值接受

BOOLii = [fate executeUpdate:str];

//判斷

if(ii) {

NSLog(@"成功");

}else{

NSLog(@"失敗");

}

//關(guān)閉

[fate close];

}

@end

================ ? ? ================

=======

4.MVC-->C模塊

控制器1 -主控制器 ?.m:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import"ViewController.h"

#import"LoadData.h"http://業(yè)務(wù)處理SQLite

#import"Model.h"http://保存數(shù)據(jù)

#import"MyTableViewCell.h"http://主控制器cell

#import"UpViewController.h"http://修改信息控制器

#import"AddViewController.h"http://添加信息控制器

@interfaceViewController(){

UITableView*tabele;

NSMutableArray*marr;

}

@end

@implementationViewController

//將要顯示

-(void)viewWillAppear:(BOOL)animated{

//查詢

marr= [[LoadDatasharlLoadData]Marr];

//刷新

[tabelereloadData];

}

- (void)viewDidLoad {

[superviewDidLoad];

//定義標題

self.title=@"信息查詢系統(tǒng)";

//初始化

tabele= [[UITableViewalloc]initWithFrame:self.view.framestyle:

UITableViewStylePlain];

//添加協(xié)議

tabele.delegate=self;

tabele.dataSource=self;

//添加到試圖上

[self.viewaddSubview:tabele];

//定義按鈕

UIBarButtonItem*right = [[UIBarButtonItemalloc]

initWithTitle:@"添加"style:UIBarButtonItemStylePlain

target:selfaction:@selector(click)];

//添加到導(dǎo)航調(diào)試

self.navigationItem.rightBarButtonItem=

right;

}

-(void)click{

//初始化

AddViewController*add = [AddViewControllernew];

//跳轉(zhuǎn)

[self.navigationControllerpushViewController:addanimated:YES];

}

//行數(shù)

-(NSInteger)tableView:(UITableView*)tableView numberOfRowsInSection:(NSInteger)section{

returnmarr.count;

}

-(UITableViewCell*)tableView:(UITableView*)tableView cellForRowAtIndexPath:(NSIndexPath*)indexPath{

//初始化

MyTableViewCell*cell = [tableViewdequeueReusableCellWithIdentifier:@"CELL"];

//復(fù)用池

if(!cell) {

//初始化‘

cell = [[MyTableViewCellalloc]initWithStyle:

UITableViewCellStyleSubtitlereuseIdentifier:@"CELL"];

}

//初始化

Model*mm =marr[indexPath.row];

//添加到表格上

cell.fieldMail.text= mm.fieldMail;

cell.fieldAddress.text= mm.fieldAddress;

cell.fieldConsignee.text= mm.fieldConsignee;

cell.fieldPhone.text= mm.fieldPhone;

cell.fieldNote.text= mm.fieldNote;

//返回值

returncell;

}

//刪除

-(void)tableView:(UITableView*)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle

forRowAtIndexPath:(NSIndexPath*)indexPath{

//添加

Model*mm? =marr[ indexPath.row];

//刪除

[[LoadDatasharlLoadData]deleteharlLoadData:mm];

[marr removeObjectAtIndex:indexPath.row];

//刷新

[tabele reloadData];

}

//跳轉(zhuǎn)

-(void)tableView:(UITableView *)tableView

didSelectRowAtIndexPath:(NSIndexPath *)indexPath{

//初始化

UpViewController *up = [UpViewController new];

//添加

up.mm = marr[indexPath.row];

//修改

[[LoadData sharlLoadData]UPsharlLoadData:up.mm];

//跳轉(zhuǎn)

[self.navigationController pushViewController:up animated:YES];

}

@end

================================

控制器2--添加信息控制器 .m:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import"AddViewController.h"

#import"Model.h"

#import"LoadData.h"

@interfaceAddViewController()

//郵件

@property(strong,nonatomic)IBOutletUITextField*fieldMail;

//收貨地址

@property(strong,nonatomic)IBOutletUITextField*fieldAddress;

//收貨人

@property(strong,nonatomic)IBOutletUITextField*fieldConsignee;

//電話

@property(strong,nonatomic)IBOutletUITextField*fieldPhone;

//備注

@property(strong,nonatomic)IBOutletUITextField*fieldNote;

//點擊添加信息

- (IBAction)sss:(id)sender;

@end

@implementationAddViewController

- (void)viewDidLoad {

[superviewDidLoad];

}

- (IBAction)sss:(id)sender {

//初始化

Model*mm = [Modelnew];

//鏈接

mm.fieldMail=self.fieldMail.text;

mm.fieldAddress=self.fieldAddress.text;

mm.fieldConsignee=self.fieldConsignee.text;

mm.fieldPhone=self.fieldPhone.text;

mm.fieldNote=self.fieldNote.text;

//添加到數(shù)據(jù)庫

[[LoadDatasharlLoadData]AddsharlLoadData:mm];

//跳轉(zhuǎn)

[self.navigationControllerpopViewControllerAnimated:YES];

}

@end

================================

控制器3--修改信息控制器 .h:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import

@classModel;

@interfaceUpViewController :UIViewController

//定義屬性

@property(nonatomic,strong)Model*mm;

@end

控制器3--修改信息控制器 .m:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import"UpViewController.h"

#import"LoadData.h"

#import"Model.h"

@interfaceUpViewController()

//郵件

@property(strong,nonatomic)IBOutletUITextField*fieldMail;

//收貨地址

@property(strong,nonatomic)IBOutletUITextField*fieldAddress;

//收貨人

@property(strong,nonatomic)IBOutletUITextField*fieldConsignee;

//電話

@property(strong,nonatomic)IBOutletUITextField*fieldPhone;

//備注

@property(strong,nonatomic)IBOutletUITextField*fieldNote;

//點擊修改信息

- (IBAction)ssss:(id)sender;

@end

@implementationUpViewController

- (void)viewDidLoad {

[superviewDidLoad];

//將數(shù)據(jù)添加到修改頁面

self.fieldMail.text =self.mm.fieldMail;

self.fieldAddress.text =self.mm.fieldAddress;

self.fieldConsignee.text =self.mm.fieldConsignee;

self.fieldPhone.text =self.mm.fieldPhone;

self.fieldNote.text =self.mm.fieldNote;

}

- (IBAction)ssss:(id)sender {

//初始化

Model *mm =self.mm;

//鏈接

mm.fieldMail =self.fieldMail.text;

mm.fieldAddress =self.fieldAddress.text;

mm.fieldConsignee =self.fieldConsignee.text;

mm.fieldPhone =self.fieldPhone.text;

mm.fieldNote =self.fieldNote.text;

//添加

[[LoadData sharlLoadData]UPsharlLoadData:mm];

//跳轉(zhuǎn)

[self.navigationController popViewControllerAnimated:YES];

}

@end

================================

=======

5.MVC-->V模塊

控制器1-- .h:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import

@interfaceMyTableViewCell :UITableViewCell

//郵件

@property(nonatomic,strong)UILabel*fieldMail;

//收貨地址

@property(nonatomic,strong)UILabel*fieldAddress;

//收貨人

@property(nonatomic,strong)UILabel*fieldConsignee;

//電話

@property(nonatomic,strong)UILabel*fieldPhone;

//備注

@property(nonatomic,strong)UILabel*fieldNote;

@end

控制器1-- .m:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import"MyTableViewCell.h"

@implementationMyTableViewCell

//重寫父類方法

-(instancetype)initWithStyle:(UITableViewCellStyle)style

reuseIdentifier:(NSString*)reuseIdentifier{

//判斷

if([superinitWithStyle:stylereuseIdentifier:reuseIdentifier])

{

//添加到

[self.contentViewaddSubview:self.fieldMail];

[self.contentViewaddSubview:self.fieldAddress];

[self.contentViewaddSubview:self.fieldConsignee];

[self.contentViewaddSubview:self.fieldPhone];

[self.contentViewaddSubview:self.fieldNote];

}

//返回值

returnself;

}

//懶加載-//郵件

-(UILabel*)fieldMail{

//判斷

if(!_fieldMail) {

//初始化

_fieldMail= [[UILabelalloc]initWithFrame:CGRectMake(5,5,80,44)];

}

//返回值

return_fieldMail;

}

//懶加載-//收貨地址

-(UILabel*)fieldAddress{

//判斷

if(!_fieldAddress) {

//初始化

_fieldAddress= [[UILabelalloc]initWithFrame:CGRectMake(80,5,80,44)];

}

//返回值

return_fieldAddress;

}

//懶加載=//收貨人

-(UILabel*)fieldConsignee{

//判斷

if(!_fieldConsignee) {

//初始化

_fieldConsignee= [[UILabelalloc]initWithFrame:CGRectMake(155,5,80,44)];

}

//返回值

return_fieldConsignee;

}

//懶加載--//電話

-(UILabel*)fieldPhone{

//判斷

if(!_fieldPhone) {

//初始化

_fieldPhone = [[UILabel alloc]initWithFrame:CGRectMake(220,5,80,44)];

}

//返回值

return_fieldPhone;

}

//懶加載

-(UILabel *)fieldNote{

//判斷

if(!_fieldNote) {

//初始化

_fieldNote = [[UILabel alloc]initWithFrame:CGRectMake(305,5,80,44)];

}

//返回值

return_fieldNote;

}

- (void)awakeFromNib {

[superawakeFromNib];

}

- (void)setSelected:(BOOL)selected animated:(BOOL)animated {

[supersetSelected:selected animated:animated];

}

@end

================================

=======

6.MVC-->M模塊

控制器1-- .h:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import

@interfaceModel :NSObject

//定義屬性

//郵箱

@property(nonatomic,copy)NSString*fieldMail;

//收貨地址

@property(nonatomic,copy)NSString*fieldAddress;

//收貨人

@property(nonatomic,copy)NSString*fieldConsignee;

//電話

@property(nonatomic,copy)NSString*fieldPhone;

//備注

@property(nonatomic,copy)NSString*fieldNote;

//

@property(nonatomic,assign)NSIntegerID;

@end

================================

控制器1--

.m:

//? Created by石虎on 2017/7/6.

//? Copyright ? 2017年shihu. All rights reserved.

//

#import"Model.h"

@implementationModel

@end

================================

=======

================================

=======

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,702評論 6 534
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,615評論 3 419
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,606評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,044評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,826評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,227評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,307評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,447評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,992評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,807評論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,001評論 1 370
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,550評論 5 361
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,243評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,667評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,930評論 1 287
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,709評論 3 393
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,996評論 2 374

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