数据库MFDB的使用

//第一步导入FMDB数据库

//第二步在Build Phasses中导入数据库:libsqlite3.tbd

//创建DataBase类,在DataBase类中创建两个基于NSObject的类对象(Tel和DataBase)

.h

@interface Tel : NSObject

@property(nonatomic,assign)NSInteger  theId;

@property(nonatomic,strong)NSString *name,*phone,*em;

@end

@interfaceDataBase :NSObject

//单例方法

+(instancetype)initData;

-(void)initSql;

-(void)addData:(Tel*)data;

-(void)update:(Tel*)data;

-(void)delData:(NSInteger)theid;

-(NSMutableArray*)showArray;

@end

.m

#import "DataBase.h"

#import "FMDatabase.h"

//创建静态变量

staticDataBase*sqlData;

static FMDatabase *db;

@implementation Tel

@end

@implementation DataBase

+(instancetype)initData{

    if(!sqlData) {

        sqlData= [DataBasenew];

    }

    return sqlData;

}

-(void)initSql{

    NSString *strPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)objectAtIndex:0];


    NSString*fileName = [strPathstringByAppendingString:@"filename.db"];

    db= [[FMDatabasealloc]initWithPath:fileName];


    if([dbopen]) {

        NSLog(@"打开数据库成功");

        [db executeUpdate:@"create table sql(theId integer primary key,name text,phone text,em text)"];

        [dbclose];

    }

    else{

       NSLog(@"打开数据库失败");

    }

}

-(void)addData:(Tel*)data{

    if([dbopen])

    {

        [db executeUpdate:[NSString stringWithFormat:@"insert into sql values(null,'%@','%@','%@')",data.name,data.phone,data.em]];

    }

    else

    {

        NSLog(@"添加数据失败");

    }


    [dbclose];

}

-(void)update:(Tel*)data{

    if([dbopen]) {

        [db executeUpdate:[NSString stringWithFormat:@"update sql set name ='%@',phone = '%@',em = '%@' where theId = '%ld'",data.name,data.phone,data.em,data.theId]];

    }

    else

    {

        NSLog(@"修改数据失败");

    }


    [dbclose];

}

-(void)delData:(NSInteger)theid

{

    if([dbopen]) {

        [db executeUpdate:[NSString stringWithFormat:@"delete from sql where theId = '%ld'",theid]];

    }

    else

    {

        NSLog(@"删除数据失败");

    }

    [dbclose];

}

-(NSMutableArray*)showArray{

    NSMutableArray *array = [NSMutableArray array];


    FMResultSet *set = [FMResultSet new];

    if([dbopen])

    {

       set = [db executeQuery:@"select *from sql"];

        while([setnext]) {

            Tel*t = [Telnew];

            t.theId= [setintForColumn:@"theId"];

            t.name= [setstringForColumn:@"name"];

            t.phone= [setstringForColumn:@"phone"];

            t.em= [setstringForColumn:@"em"];


            [arrayaddObject:t];

        }


    }

    else

    {

        NSLog(@"查询数据失败");

    }

    [dbclose];

    returnarray;

}

@end

//创建基于:UIView的类(TelView)

.h

@interfaceTelView :UIView

@property(nonatomic,strong)UITextField*nameTf,*phoneTf,*emTf;

@end

.m

#import "TelView.h"

@implementation TelView

-(instancetype)initWithFrame:(CGRect)frame{


    if(self= [superinitWithFrame:frame]) {

        [selfaddSubview:self.nameTf];

        [selfaddSubview:self.phoneTf];

        [selfaddSubview:self.emTf];


    }

    return self;

}

-(UITextField*)nameTf{


    if(!_nameTf) {

        _nameTf= [[UITextFieldalloc]initWithFrame:CGRectMake(0,90,self.frame.size.width,44)];


        _nameTf.placeholder = @"please you name";


        _nameTf.textAlignment = NSTextAlignmentCenter;


        _nameTf.borderStyle = UITextBorderStyleRoundedRect;

    }

    return _nameTf;

}

-(UITextField*)phoneTf{


    if(!_phoneTf) {

        _phoneTf= [[UITextFieldalloc]initWithFrame:CGRectMake(0,140,self.frame.size.width,44)];


        _phoneTf.placeholder = @"please you phone";


        _phoneTf.textAlignment = NSTextAlignmentCenter;


        _phoneTf.borderStyle = UITextBorderStyleRoundedRect;

    }

    return _phoneTf;

}

-(UITextField *)emTf{


    if(!_emTf)

    {

        _emTf= [[UITextFieldalloc]initWithFrame:CGRectMake(0,190,self.frame.size.width,44)];


        _emTf.placeholder = @"please you email";


        _emTf.textAlignment = NSTextAlignmentCenter;


        _emTf.borderStyle = UITextBorderStyleRoundedRect;

    }

    return _emTf;

}

@end

//创建导航条

//在AppDelgate.m中添加以下代码

#import "ViewController.h"

@interface AppDelegate ()

@end

@implementation AppDelegate

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

    self.window.rootViewController =

    [[UINavigationController alloc]initWithRootViewController:[ViewController new]];

    return YES;

}

//在ViewController.h中把UIViewController 修改成:UITableViewController

.m  添加以下代码

#import "ViewController.h"

//Model

#import "DataBase.h"

//Controller

#import "SecViewController.h"

@interface ViewController ()

{

    NSMutableArray *array;

}

@end

@implementation ViewController

- (void)viewDidLoad {

    [super viewDidLoad];


    self.title=@"通讯录";


    UISearchBar*search = [[UISearchBaralloc]initWithFrame:CGRectMake(0,0,self.view.frame.size.width,44)];

    self.tableView.tableHeaderView = search;

    //创建右按钮

    self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithTitle:@"添加" style:UIBarButtonItemStylePlain target:self action:@selector(click)];

    //设置行高

    self.tableView.rowHeight = 90;

    //初始化数组

    array = [NSMutableArray array];

}

-(void)click{


    [self.navigationController pushViewController:[SecViewController new] animated:YES];

}

//视图将要展示

-(void)viewWillAppear:(BOOL)animated

{

    [[DataBase initData]initSql];


    array = [[DataBase initData]showArray];


    [self.tableView reloadData];

}

#pragma mark -

#pragma mark UITableViewDataSource

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

{

    returnarray.count;

}

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


    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@""];

    if(!cell)

    {

        cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@""];

    }

    Tel*t =array[indexPath.row];


    cell.textLabel.text= [NSStringstringWithFormat:@"%ld\n姓名:%@\n手机号:%@\n邮箱:%@",t.theId,t.name,t.phone,t.em];


    cell.textLabel.numberOfLines = 0;


    returncell;

}

-(void)tableView:(UITableView*)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath*)indexPath{


    [[DataBase initData]initSql];


    [[DataBaseinitData]delData:[array[indexPath.row]theId]];


    [arrayremoveObject:array[indexPath.row]];


    [self.tableView reloadData];

}

-(void)tableView:(UITableView*)tableView didSelectRowAtIndexPath:(NSIndexPath*)indexPath{

SecViewController *sec = [SecViewController new];

    sec.t=array[indexPath.row];

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

}

@end

//创建SecViewController

在.h好中添加头文件和声明属性:

#import "DataBase.h"

@property(nonatomic,strong)Tel *t;

在.m文件夹中添加以下大码

//Model

#import "DataBase.h"

//View

#import "TelView.h"

@interface SecViewController ()

{

    TelView*tview;

}

@end

@implementationSecViewController

- (void)viewDidLoad {

    [super viewDidLoad];


    tview = [[TelView alloc]initWithFrame:self.view.frame];


    tview.backgroundColor = [UIColor lightGrayColor];


    self.view=tview;

    tview.nameTf.text = self.t.name;

    tview.phoneTf.text = self.t.phone;

    tview.emTf.text = self.t.em;


    if(!self.t) {

        self.title=@"添加数据";

        self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithTitle:@"保存" style:UIBarButtonItemStylePlain target:self action:@selector(save)];

    }

    else{

        self.title=@"修改数据";

        self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithTitle:@"修改" style:UIBarButtonItemStylePlain target:self action:@selector(change)];

    }


}

-(void)save

{

    Tel*tel = [Telnew];


    tel.name = tview.nameTf.text;

    tel.phone = tview.phoneTf.text;

    tel.em=tview.emTf.text;


    [[DataBase initData]initSql];

    [[DataBase initData]addData:tel];

    [self.navigationController popViewControllerAnimated:YES];

}

-(void)change

{

    self.t.name =tview.nameTf.text;

    self.t.phone = tview.phoneTf.text;

    self.t.em = tview.emTf.text;


    [[DataBase initData]initSql];


    [[DataBase initData]update:self.t];


    [self.navigationController popViewControllerAnimated:YES];

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,744评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,505评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,105评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,242评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,269评论 6 389
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,215评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,096评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,939评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,354评论 1 311
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,573评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,745评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,448评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,048评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,683评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,838评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,776评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,652评论 2 354

推荐阅读更多精彩内容

  • 哦吼吼,又研究了几天,把FMDB这个封装好的数据库搞定了,写了个简单的例子,基于FMDB的添删改查操作,界面很一般...
    lichengjin阅读 527评论 0 0
  • 作者唯一QQ:228544117。。。。。 =========后面的都要新建一个文章 AppDelegate.h ...
    CC_iOS阅读 852评论 0 0
  • 概述在iOS开发中UITableView可以说是使用最广泛的控件,我们平时使用的软件中到处都可以看到它的影子,类似...
    liudhkk阅读 9,037评论 3 38
  • #import<Foundation/Foundation.h> #import #import "sqlTest...
    lichengjin阅读 413评论 0 0
  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 2,029评论 0 2