FMDB数据库框架的是使用

IOS操作数据库,SQLite3和coredata是两个非常好的选择,但是对于我们这些掌握了其他数据库语言的人来说,使用这两中操作都会觉得不方便,SQLite3使用起来太复杂了,而使用coredata的时候却封装太死了,我们需要自己些自己的数据库语句,这时候,FMDB就是一个非常不错的选择

下面是FMDB的基本使用

在Main.storyboard中添加4个按钮分别是(插入 , 更新,删除 , 查询)

在ViewController中

//

//  ViewController.m

 

//

//

 

#import "ViewController.h"

#import "FMDB.h"

 

@interface ViewController ()

@property (nonatomic, strong) FMDatabase *db;

- (IBAction)insert;

- (IBAction)update;

- (IBAction)delete;

- (IBAction)query;

@end

 

@implementation ViewController

 

- (void)viewDidLoad

{

    [super viewDidLoad];

    

    // 0.获得沙盒中的数据库文件名

    NSString *filename = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"student.sqlite"];

    

    // 1.创建数据库实例对象

    self.db = [FMDatabase databaseWithPath:filename];

   

    // 2.打开数据库

    if ( [self.db open] ) {

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

        

        // 创表

        BOOL result = [self.db executeUpdate:@"create table if not exists t_student (id integer primary key autoincrement, name text, age integer);"];

        

        if (result) {

            NSLog(@"创表成功");

        } else {

            NSLog(@"创表失败");

        }

    } else {

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

    }

}

 

- (IBAction)insert

{

    for (int i = 0; i<40; i++) {

        NSString *name = [NSString stringWithFormat:@"rose-%d", arc4random() % 1000];

        NSNumber *age = @(arc4random() % 100 + 1);

        [self.db executeUpdate:@"insert into t_student (name, age) values (?, ?);", name, age];

    }

}

 

- (IBAction)update

{

    [self.db executeUpdate:@"update t_student set age = ? where name = ?;", @20, @"jack"];

}

 

- (IBAction)delete

{

    

}

 

- (IBAction)query

{

    // 1.查询数据

    FMResultSet *rs = [self.db executeQuery:@"select * from t_student where age > ?;", @50];

    

    // 2.遍历结果集

    while (rs.next) {

        int ID = [rs intForColumn:@"id"];

        NSString *name = [rs stringForColumn:@"name"];

        int age = [rs intForColumn:@"age"];

        

        NSLog(@"%d %@ %d", ID, name, age);

    }

}

@end

 

转载于:https://www.cnblogs.com/cainiao-blogs/p/4070844.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值