fmdb 数据库的基本操作
/**
* 创建表
*/
- (void)createTable
{
//1.初始化数据库对象 并且 2.打开数据库
BOOL isOpenSuccess = [self.database open];
NSLog(@"数据库打开%@",isOpenSuccess?@"成功":@"失败");
//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(@"创建表%@",isCreateTableOK?@"成功":@"失败");
}
//初始化数据库对象
- (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(@"插入数据%@",isInsertOK?@"成功":@"失败");
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(@"==========更新数据%@===========",isInsertOK?@"成功":@"失败");
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;
}
fmdb 数据库的基本操作的更多相关文章
- FMDB 数据库
iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepers ...
- mysql数据库的基本操作
mysql数据库的基本操作dos命令启动mysql服务:net start mysql启动数据库: mysql -uroot -p查看所有的数据库:show databases:新建数据库:creat ...
- MySQL(一) 数据表数据库的基本操作
序言 这类文章,记录我看<MySQL5.6从零开始学>这本书的过程,将自己觉得重要的东西记录一下,并有可能帮助到你们,在写的博文前几篇度会非常基础,只要动手敲,跟着我写的例子全部实现一遍, ...
- iOS开发数据库篇—FMDB数据库队列
iOS开发数据库篇—FMDB数据库队列 一.代码示例 1.需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库. 2.代码如下: // // YYViewContr ...
- Swift使用单个案件管理FMDB数据库
下班... 抢 我曾经Swift使用单一个案管理FMDB数据库的方法共享出来: // Created by 秦志伟 on 14-6-12. import UIKit class ZWDBManager ...
- PostgreSQL自学笔记:3 数据库的基本操作
3 数据库的基本操作 3.1 创建数据库 3.1.1 使用对象浏览器创建数据库 [Server] -> PostgreSQL 9.6 -> 数据库,右击 -> 创建 通常: 数据库: ...
- ThinkPhp框架对“数据库”的基本操作
框架有时会用到数据库的内容,在"ThinkPhp框架知识"的那篇随笔中提到过,现在这篇随笔详细的描述下. 数据库的操作,无疑就是连接数据库,然后对数据库中的表进行各种查询,然后就是 ...
- mysql 数据库(二)数据库的基本操作
mysql 数据库(二)数据库的基本操作 用户管理,添加权限,创建,显示,使用数据库 1 显示数据库:show databases; 默认数据库: mysql - 用户权限相关数据 test - 用于 ...
- MySQL:数据库的基本操作
第二篇.数据库的基本操作 一.创建数据库 附:创建数据库并不意味输入数据在这个数据库中,只有用切换数据库才可以输数据到这个数据库中. 1.创建数据库 格式:create database数据库名字 [ ...
随机推荐
- Android自定义Dialog(美化界面)
前言:在做项目的时候,发现dialog界面太丑陋,从csdn上下载了一份自定义dialog的源码,在他的基础上对界面进行美化...有需要的朋友可以直接拿走 效果图如下: 主要代码: /** * 自定义 ...
- 如何利用脚本实现MySQL的快速部署以及一机多实例的部署
MySQL有三个版本:二进制,源码包,RPM. 下面讲讲二进制包的安装过程 下载地址: http://dev.mysql.com/downloads/mysql/ 选择Linux-Generic 我这 ...
- ASP.NET MVC Application_Error 无效不执行
我们一般在开发 ASP.NET MVC 应用程序的时候,会在 Application_Error 中添加异常日志记录,一般会记录 500 的错误信息,但如果应用程序在出错的时候,Application ...
- 【记录】T-SQL 分组排序中取出最新数据
示例 Product 表结构: 示例 Product 表数据: 想要的效果是,以 GroupName 字段分组,取出分组中通过 Sort 降序最新的数据,通过示例数据,可以推算出结果数据的 ID 应该 ...
- 优化JS加载时间过长的一种思路
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.背景 去年公司在漳州的一个项目中,现场工程人员反映地图部分出图有点 ...
- 初识openstack
<1>虚拟化技术的功能和特点 多个虚拟机运行在一台物理服务器上,虚拟机之间共享物理资源,虚拟机可以分别安装不同的操作系统,应用程序相互隔离. 虚拟化技术的优势:虚拟机的操作系统和应用程序不 ...
- C#动态调用WCF接口,两种方式任你选。
写在前面 接触WCF还是它在最初诞生之处,一个分布式应用的巨作. 从开始接触到现在断断续续,真正使用的项目少之又少,更谈不上深入WCF内部实现机制和原理去研究,最近自己做一个项目时用到了WCF. 从这 ...
- Android 源码下载方法(Git 方式clone)
Android源码对于Android开发者来说,迟早有一天你会用到的,所以就记录一下,分享给读者,希望对读者有用 这里需要使用到Git相关知识,不清楚的可以先阅读,了解的可以跳过 Git-Tortoi ...
- springmvc原理
今天面试碰到一个特别恶心的公司面试官.是一个金融公司,过去后告诉我2点上班,带我去见经理.经理找人面试,看起来没有hr,经理直接看简历招人.经理上来就问我是xxx大学的,我说是,然后等面试官.面试官来 ...
- Final Cut Pro X效果插件开发总结
一.介绍 最近公司需要针对Final Cut Pro(FCP)开发一款效果插件,用于对公司自己开发的视频格式进行后期处理.Final Cut Pro是苹果公司推出的一款视频剪辑软件,因此需要在OSX平 ...