iOS:第三方数据库文件FMDB的使用
第三方数据库FMDB
FMDatabase:对象就代表一个单独的SQLite数据库用来执行SQL语句
FMResultSet:使用FMDatabase执行查询后的结果集
- (BOOL)next;
-{type}ForColumnIndex:(int)columnIdx
执行SQL语句:
self.db = [FMDatabase databaseWithPath:fileName]; //创建数据库
[self.db open];//打开数据库
[self.db close]; //关闭数据库
//对数据库进行插入、修改的操作
[self.db executeUpdate:@“CREATE TABLE IF NOT EXISTS t_student (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name TEXT,age INTEGER)”];
[self.db executeUpdate:@"INSERT INTO t_student(name , age) VALUES(?, ?);", @"xuneng", @(10)];
[self.db executeUptate:@"update t_student set name = 'lisi' where age = @(10)"];
<2>查询:FMResultSet类(数据取出完全后,不需要再去关闭结果集,当新的结果集产生,或者其数据库关闭时,会自动关闭。)
// 1.查询
FMResultSet *set = [self.db executeQuery:@"SELECT * FROM t_student;"]; //返回结果集
// 2.取出数据
while ([set next])
{
// 取出姓名
NSString *name = [set stringForColumnIndex:1];
// 取出年龄
int age = [set intForColumnIndex:2];
NSString *name = [set stringForColumn:@"name"];
int age = [set intForColumn:@"age"];
NSLog(@"name = %@, age = %d", name, age);
}
创建数据库并进行增删改查的操作举例如下:
1、首先导入sqlite本地数据库和第三方数据库FMDB
2、在UIViewController类中对数据库表进行增删该查操作如下:
《1》数据库路径
NSArray *dics = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *dbPath = [[dics lastObject] stringByAppendingPathComponent:@"user.db"];
《2》 创建数据库
self.db = [FMDatabase databaseWithPath:dbPath];
《3》打开数据库
if(![self.db open])
{
return; //打开数据库失败
}
《4》创建数据库表
if(![self.db executeUpdate:@"create table if not exists user (ID integer primary key autoincrement,name text,password text)"])
{
return; //创建数据库表失败
}
《5》插入数据
if(![self.db executeUpdate:@"insert into user (name,password) values('admin','123456')"])
{
return; //插入数据失败
}
《6》修改数据
if(![self.db executeUpdate:@"update user set name = 'zhangsan' where ID = 2"])
{
return; //修改数据失败
}
《7》获取结果集
FMResultSet *resultSet = [self.db executeQuery:@"select * from user"];
《8》遍历结果集,取出数据
while ([resultSet next])
{
int ID = [resultSet intForColumnIndex:0];
NSString *name = [resultSet stringForColumnIndex:1];
NSString *password = [resultSet stringForColumnIndex:2];
NSLog(@"ID:%d,name:%@,password:%@",ID,name,password);
}
《8》//关闭数据库
[self.db close];
演示结果如下:
-- ::38.640 第三方数据库FMDB[:] ID:,name:admin,password:
-- ::38.641 第三方数据库FMDB[:] ID:,name:zhangsan,password:
-- ::38.641 第三方数据库FMDB[:] ID:,name:admin,password:
-- ::38.641 第三方数据库FMDB[:] ID:,name:admin,password:
-- ::38.641 第三方数据库FMDB[:] ID:,name:admin,password:
iOS:第三方数据库文件FMDB的使用的更多相关文章
- iOS开发数据库篇—FMDB简单介绍
iOS开发数据库篇—FMDB简单介绍 一.简单说明 1.什么是FMDB FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言API 2.FMDB的优点 使用起来 ...
- iOS开发数据库篇—FMDB数据库队列
iOS开发数据库篇—FMDB数据库队列 一.代码示例 1.需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库. 2.代码如下: // // YYViewContr ...
- IOS第三方数据库--FMDB
iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepers ...
- IOS第三方数据库--FMDB 分类: ios技术 2015-03-01 09:38 57人阅读 评论(0) 收藏
iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepers ...
- iOS 把数据库文件打包到mainbundle中,查找不到路径的解决的方法;以及在删除bundle中文件的可行性
在开发中有时我们须要把数据库文件打包到我们的项目中.一般我们都是在外部用工具生成数据库文件,然后拉入项目中.可是我们在程序中查找改文件时.返回的路径总是nil 解决的方法: 原因我们拉入其它资源文件( ...
- iOS开发数据库-FMDB
前言 FMDB是以OC的方式封装了SQLite的C语言API,使用起来更加面向对象,省去了很多麻烦.冗余的C语言代码:对比苹果自带的Core Data框架,更加轻量级和灵活:提供了多线程安全的数据库操 ...
- QF——iOS中的数据库操作:SQLite数据库,第三方封装库FMDB,CoreData
SQLite数据库: SQLite是轻量级的数据库,适合应用在移动设备和小型设备上,它的优点是轻量,可移植性强.但它的缺点是它的API是用C写的,不是面向对象的.整体来说,操作起来比较麻烦.所以,一般 ...
- IOS学习笔记28—SQLite3第三方库之FMDB
本文转载至 http://blog.csdn.net/happyrabbit456/article/details/11609451 SQLite是一种小型的轻量级的关系型数据库,在移动设备上使用是非 ...
- IOS数据存储之FMDB数据库
前言: 最近几天一直在折腾数据库存储,之前文章(http://www.cnblogs.com/whoislcj/p/5485959.html)介绍了Sqlite 数据库,SQLite是一种小型的轻量级 ...
随机推荐
- win10自动更新失败
十一过后,win10 总是提示自动更新失败,每天都会重启一次,按照官方给出的操作进行了也不好使, 后来就关闭更新,没有再打开 ------------------------------------- ...
- int类中的方法(二)
25.__pos__(self,*args,**kwargs) def __pos__(self, *args, **kwargs): # real signature unknown &qu ...
- WPF 获取指定文件的Icon
C# var icon = System.Drawing.Icon.ExtractAssociatedIcon(@"filepath"); var m = new MemorySt ...
- 【LOJ】 #2521. 「FJOI2018」领导集团问题
题解 这道题很显然可以想出来一个\(n^2\)的dp,也就是dp[u][i]表示以u为根的子树最大值是i的点集最大是多少(i是离散化后的值) 就是对于每个儿子处理出后缀最大值然后按位相加更新父亲,我们 ...
- loadrunner中并发数与迭代的区别
你的理解的虚拟用户应该是 迭代次数 ,录制脚本时只会有1个虚拟用户,1个虚拟用户可以有多次 迭代,也就是 重复执行 Action里面的内容,在场景设置的时候,如果你说的10时在runtime-sett ...
- 【转】Vue v-bind与v-model的区别
v-model 指令在表单控件元素上创建双向数据绑定,所谓双向绑定,指的就是我们在js中的vue实例中 的data与其渲染的dom元素上的内容保持一致,两者无论谁被改变,另一方也会相应的更新为相同的数 ...
- export导出.xls时,在火狐的情况下出现表名乱码的情况的解决方案
response.setContentType("application/octet-stream; charset=utf-8");fileName = exportDataDt ...
- 【Java学习】调用ByteBuffer.getInt()方法得到808464432
调用ByteBuffer.getInt()方法遇到的奇怪错误 最近在参加阿里的中间件比赛,中间用到了RocketMQ的思想,并且主要集中在使用NIO来读写文件.其中遇到了一个很蛋疼的问题,想了半天想不 ...
- Git in Powershell saying 'Could not find ssh-agent'
加入系统环境变量D:\Program Files\Git\usr\bin
- 安卓 listView 优化
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_m ...