fmdb 数据库的基本操作

/**

*  创建表

*/

- (void)createTable

{

//1.初始化数据库对象 并且 2.打开数据库

BOOL isOpenSuccess = [self.database open];

NSLog(@"数据库打开%@",[email protected]"成功":@"失败");

//3.创建表

NSString *sql = @"create table if not exists User (id integer primary key autoincrement, name text, age integer, icon blob)";

//执行sql,除了查询外,其他的操作都是更新

BOOL isCreateTableOK = [self.database executeUpdate:sql];

NSLog(@"创建表%@",[email protected]"成功":@"失败");

}

//初始化数据库对象

- (FMDatabase *)database

{

if (!_database)

{

_database = [FMDatabase databaseWithPath:[self databasePath]];

}

return _database;

}

/**

*  返回数据库路径

*

*  @return return value description

*/

- (NSString *)databasePath

{

//获取document路径

NSString *docuentPath = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)[0];

return [docuentPath stringByAppendingPathComponent:@"user.db"];

}

/**

*  插入指定数据

*

*  @param user user description

*

*  @return return value description

*/

- (BOOL)insertUserObjectWithUser:(User *)user

{

NSString *sql = @"insert into User (name,age,icon) values (?,?,?)";

//执行插入的sql语句

BOOL isInsertOK = [self.database executeUpdate:sql,user.name,@(user.age),user.iconData];

NSLog(@"插入数据%@",[email protected]"成功":@"失败");

return YES;

}

/**

*  更新数据

*

*  @param user user description

*

*  @return return value description

*/

- (BOOL)updateUserObjectWithUser:(User *)user

{

NSString *sql = [NSString stringWithFormat:@"update user set name=‘%@‘,age=‘%d‘,icon=‘%@‘ where name = ‘%@‘",user.name,user.age,user.iconData,user.name];

BOOL isInsertOK = [self.database executeUpdate:sql];

NSLog(@"==========更新数据%@===========",[email protected]"成功":@"失败");

return YES;

}

/**

*  查询所有的数据

*

*  @return return value description

*/

- (NSArray *)queryAllUserObjectsFromDatabase

{

//保存所有的用户信息

NSMutableArray *users = [NSMutableArray array];

NSString *sql = @"select * from User";

//执行查询

FMResultSet *result = [self.database executeQuery:sql];

//遍历

while (result.next)

{

User *user = [[User alloc] init];

//取值

//根据字段名字取值

user.iconData = [result dataForColumn:@"icon"];

user.name = [result stringForColumn:@"name"];

user.age = [result intForColumn:@"age"];

[users addObject:user];

}

return users;

}

时间: 2024-08-08 21:56:20

fmdb 数据库的基本操作的相关文章

TP框架对数据库的基本操作

数据库的操作,无疑就是连接数据库,然后对数据库中的表进行各种查询,然后就是对数据的增删改的操作,一步步的讲述一下框架对数据库的操作 想要操作数据库,第一步必然是要:链接数据库 一.链接数据库 (1)找到模块文件夹中的Conf文件夹,然后进行编写config.php文件 我这里是这样的文件路径 (2)打开这个config.php文件,然后找到父类配置文件convention.php文件,将关于"数据库"的部分复制粘贴到config.php配置文件中 1 2 3 4 5 6 7 8 9 /

iOS开发数据库篇—FMDB数据库队列(下)

iOS开发数据库篇—FMDB数据库队列(下) 一.代码示例 1.需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库. 2.代码如下: 1 // 2 // YYViewController.m 3 // 05-FMDB数据库队列 4 // 5 // Created by apple on 14-7-28. 6 // Copyright (c) 2014年 wendingding. All rights reserved. 7 // 8 9 #import "Y

FMDB数据库的简单实用

引入和FMDB第三方类库,  demo地址:http://pan.baidu.com/s/1c0pbfxA 1 #define dataBasePath [[(NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES)) lastObject]stringByAppendingPathComponent:dataBaseName] 2 #define dataBaseName @"MyDatabase

Linux下MYSQL数据库的基本操作

建立数据库: mysql> create database test; //建立一个名为"test"的数据库 建立数据库表: mysql> create table test -> (name char(16) not null, -> passwd char(16) ->); //建立一个名为"test"的表,里面有两个字段,一个字段名为"name",类型为char,大小为16,非空:另一个字段名为"pa

PHP对于数据库的基本操作——更新数据

PHP对于数据库的基本操作--更新数据 主要的语句:$update = mysql_query("update user set password='abc' where username='123'"); 这句话的意思是,更新user表,设置passWord字段的值为abc,筛选条件为username为123的数据.就是修改user表里面username为123字段里面的password,将password的值为abc. 前面的随笔里面忘了说  where 这个了,这个我理解为筛选,

iOS开发数据库篇—FMDB数据库队列

iOS开发数据库篇—FMDB数据库队列 一.代码示例 1.需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库. 2.代码如下: 1 // 2 // YYViewController.m 3 // 05-FMDB数据库队列 4 // 5 // Created by apple on 14-7-28. 6 // Copyright (c) 2014年 wendingding. All rights reserved. 7 // 8 9 #import "YYVi

android小功能实现之SQLite数据库的基本操作

 创建一个Android工程 一 新建数据库 1 新建一个类DBOpenHelper 内容如下: import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; public class DBOpenHelper extends SQLiteOpenHelper { public DBOpenHelpe

FMDB 数据库的使用

FMDB 数据库 和 SQLite3 非常相似  但要比 SQLite3 省好多代码  没有了各种绑定 直接引用 FMDB 的方法就可以简单解决 首先 FMDB 他还是一个单例类  因为要被其他类 使用 FMDB 还是由 打开数据库  创建数据名   添加数据   更新数据   删除数据  查询数据 几部分内容 在这里 model 的属性除了 image 外都是 NSString 类型  image 是 NSData 类型 所以在下面的查询处会有一个转换方式 打开数据库: 先 获取路径  在调用

iOS数据持久化—FMDB数据库队列

iOS开发数据库篇—FMDB数据库队列 一.代码示例 1.需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库. 2.代码如下: 1 // 2 // YYViewController.m 3 // 05-FMDB数据库队列 4 // 5 // Created by apple on 14-7-28. 6 // Copyright (c) 2014年 wendingding. All rights reserved. 7 // 8 9 #import "YYVi