(一一四)使用FMDB操作SQLite数据库

上节介绍了用系统自带的C语言库操作SQLite的方法,比较繁琐,使用FMDB会大幅度简化,并且是面向对象的,使用十分方便。

使用步骤如下:

先从github下载FMDB框架,然后把它导入工程。

①导入libsqlite3.0.dylib库。

②导入主头文件FMDatabase.h。

③创建数据库对象,传入路径,打开数据库,如果数据库不存在会被创建。

NSString *sqlitePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"test1.sqlite"];
FMDatabase *db = [FMDatabase databaseWithPath:sqlitePath];
[db open];
④查询操作使用 executeQuery:方法,其他操作使用 executeUpdate:方法。

例如创建表格和插入数据都是使用Update。

需要注意的是OC字符串以%@出现在SQL语句中不用单引号包括,否则会使得存入的数据成为?。

// 建表
[db executeUpdate:@"CREATE TABLE IF NOT EXISTS t_product (id integer PRIMARY KEY AUTOINCREMENT, name text NOT NULL, price real);"];
// 插入数据
// 注意如果使用OC字符串%@,不用单引号
[db executeUpdateWithFormat:@"INSERT INTO t_product (name,price) values (%@,%d)",[NSString stringWithFormat:@"饮料%d",arc4random_uniform(10000)],arc4random_uniform(100)];
⑤查询操作通过Query,拿到结果集,结果集可以看作迭代器,调用next属性到达下一个元素,当前位置可以取出元素,如下:

// 查询数据
FMResultSet *set = [db executeQuery:@"SELECT * FROM t_product"];
while (set.next) {
    NSString *name = [set stringForColumn:@"name"];
    double price = [set doubleForColumn:@"price"];
    NSLog(@"%@ %f",name,price);
}

转载于:https://www.cnblogs.com/aiwz/p/6154067.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值