iOSFMDB和CoreData
转发:http://wenku.baidu.com/link?url=LSPSZSPxN4pVwWNwqEXSoY0-jlnXq-_14C7qV1FV9_gFIMPjdKlXrG4Nrh_08EZS10IcYm3syaulljwJ0djvOjePa8Hl9Rq1GvZv50yz7bi
FMDB是用于进行数据存储的第三方的框架,它与SQLite与Core Data相比较,存在很多优势。
FMDB是面向对象的,它以OC的方式封装了SQLite的C语言API,使用起来更加的方便,不需要过多的关心数据库操作的知识。但是它本身也存在一些问题,比如跨平台,因为它是用oc的语言封装的,所以只能在ios开发的时候使用,如果想实现跨平台的操作,来降低开发的成本和维护的成本,就需要使用比较原始的SQLite。
Core Data是ORM的一种体现,使用Core Data需要用到模型数据的转化,虽然操作简单,不需要直接操作数据库,但是性能没有直接使用SQLite高。但是SQLite使用的时候需要使用c语言中的函数,操作比较麻烦,因此需要对它进行封装。但是如果只是简单地封装,很可能会忽略很多重要的细节,比如如何处理并发以及安全性更问题。
因此,在这里推荐使用第三方框架FMDB,它是对libsqlite3框架的封装,用起来的步骤与SQLite使用类似,并且它对于多线程的同时操作一个表格时进行了处理,也就意味着它是线程安全的。FMDB是轻量级的框架,使用灵活,它是很多企业开发的首选。
FMDB中重要的类
FMDatabase:一个FMDatabase对象就代表一个单独的SQLite数据库,用来执行SQL语句
FMResultSet:使用FMDatabase执行查询后的结果集
FMDatabaseQueue:用于在多线程中执行多个查询或更新,它是线程安全的
FMDB使用步骤
1. 下载FMDB文件 fmdb下载地址 ,将FMDB文件夹添加到项目中
2. 导入sqlite框架,导入FMDatabase.h文件
3.与SQLite使用步骤类似,需要获取数据库文件路径,然后获得数据库,并打开数据库,然后数据库进行操作,最后关闭数据库。代码如下所示:
1. // ViewController.m
2. // JRFMDB
3. //
4. // Created by jerehedu on 15/6/18.
5. // Copyright (c) 2015年 jerehedu. All rights reserved.
6. //
- 7.
8. #import "ViewController.h"
9. #import "FMDatabase.h"
- @interface ViewController ()
- @property (nonatomic, strong) FMDatabase *db;
- @end
- @implementation ViewController
- - (void)viewDidLoad
- {
- [super viewDidLoad];
- //导入sqlite框架,导入FMDB文件夹
- //1.获得数据库文件的路径
- NSString *doc=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
- NSString *fileName=[doc stringByAppendingPathComponent:@"student.sqlite"];
- NSLog(@"fileName = %@",fileName);
- //2.获得数据库
- FMDatabase *db = [FMDatabase databaseWithPath:fileName];
- //3.打开数据库
- if ([db open]) {
- NSLog(@"ok");
- //4.创表
- BOOL result=[db executeUpdate:@"CREATE TABLE IF NOT EXISTS t_student (id integer PRIMARY KEY AUTOINCREMENT, name text NOT NULL, age integer NOT NULL);"];
- if (result) {
- NSLog(@"创表成功");
- }else{
- NSLog(@"创表失败");
- }
- }
- self.db=db;
- //插入数据
- [self insertStu];
- [self deleteStu:6];
- [self updateStu:@"apple7_name" :@"7777"];
- [self queryStu];
- [self dropStu];
- [self insertStu];
- [self queryStu];
- //6.关闭数据库
- [self.db close];
- }
- #pragma mark 插入数据
- -(void)insertStu
- {
- for (int i=0; i<10; i++)
- {
- NSString *name = [NSString stringWithFormat:@"1apple%i_name",i];
- int age = arc4random()%3+20;
- //1. executeUpdate : 不确定的参数用?来占位 (后面参数必须都是oc对象)
- [self.db executeUpdate:@"INSERT INTO t_student (name, age) VALUES (?,?);",name,@(age)];
- //2. executeUpdateWithFormat : 不确定的参数用%@、%d等来占位 (参数为原始数据类型)
- // [self.db executeUpdateWithFormat:@"insert into t_student (name, age) values (%@, %i);",name,age];
- //3. 数组
- // [self.db executeUpdate:@"INSERT INTO t_student (name, age) VALUES (?,?);" withArgumentsInArray:@[name,@(age)]];
- }
- }
- #pragma mark 删除数据
- -(void)deleteStu:(int)idNum
- {
- //a. executeUpdate : 不确定的参数用?来占位 (后面参数必须都是oc对象)
- // [self.db executeUpdate:@"delete from t_student where id=?;",@(idNum)];
- //b. executeUpdateWithFormat : 不确定的参数用%@、%d等来占位
- // [self.db executeUpdateWithFormat:@"delete from t_student where name=%@;",@"apple9_name"];
- }
- #pragma mark 销毁表格
- -(void)dropStu
- {
- [self.db executeUpdate:@"drop table if exists t_student;"];
- //4.创表
- BOOL result=[self.db executeUpdate:@"CREATE TABLE IF NOT EXISTS t_student (id integer PRIMARY KEY AUTOINCREMENT, name text NOT NULL, age integer NOT NULL);"];
- if (result) {
- NSLog(@"再次创表成功");
- }else{
- NSLog(@"再次创表失败");
- }
- }
- #pragma mark 修改数据
- -(void)updateStu:(NSString *)oldName :(NSString*)newName
- {
- // [self.db executeUpdateWithFormat:@"update t_student set name=%@ where name=%@;",newName,oldName];
- [self.db executeUpdate:@"update t_student set name=? where name=?",newName,oldName];
- }
- #pragma mark 查询数据
- -(void)queryStu
- {
- //1.执行查询语句
- // FMResultSet *resultSet = [self.db executeQuery:@"select * from t_student;"];
- FMResultSet *resultSet = [self.db executeQuery:@"select * from t_student where id<?;",@(14)];
- //2.遍历结果集合
- while ([resultSet next]) {
- int idNum = [resultSet intForColumn:@"id"];
- NSString *name = [resultSet objectForColumnName:@"name"];
- int age = [resultSet intForColumn:@"age"];
- NSLog(@"id=%i ,name=%@, age=%i",idNum,name,age);
- }
- }
- - (void)didReceiveMemoryWarning
- {
- [super didReceiveMemoryWarning];
- // Dispose of any resources that can be recreated.
- }
- @end
iOSFMDB和CoreData的更多相关文章
- iOS基本数据库存储方式 - CoreData
CoreData 创建模型文件的过程 1.选择模板 2.添加实体 3.添加实体的属性[注意]属性的首字母必须小写 一.CoreData管理类(必备以下三个类对象) 1.CoreData数据操作的上下文 ...
- iOS CoreData 中 objectID 的不变性
关于 CoreData的 objectID 官方文档有这样的表述:新建的Object还没保存到持久化存储上,那么它的objectID是临时id,而保存之后,就是持久化的id,不会再变化了. 那么,我想 ...
- CoreData __ 基本原理
操作过程 Context想要获取值,先要告诉连接器,我要什么东西 链接器再告诉store, 你给我什么东西, store去找 找到之后返回给链接器,链接器再返回给Context Co ...
- iOS CoreData primitive accessor
Given an entity with an attribute firstName, Core Data automatically generates firstName, setFirstNa ...
- 初识CoreData与详解
Core Data数据持久化是对SQLite的一个升级,它是iOS集成的,在说Core Data之前,我们先说说在CoreData中使用的几个类. (1)NSManagedObjectModel(被管 ...
- CoreData教程
网上关于CoreData的教程能搜到不少,但很多都是点到即止,真正实用的部分都没有讲到,而基本不需要的地方又讲了太多,所以我打算根据我的使用情况写这么一篇实用教程.内容将包括:创建entity.创建r ...
- CoreData和SQLite多线程访问时的线程安全
关于CoreData和SQLite多线程访问时的线程安全问题 数据库读取操作一般都是多线程访问的.在对数据进行读取时,我们要保证其当前状态不能被修改,即读取时加锁,否则就会出现数据错误混乱.IOS中常 ...
- IOS数据存储之CoreData使用优缺点
前言: 学习了Sqlite数据之后认真思考了一下,对于已经习惯使用orm数据库的开发者或者对sql语句小白的开发者来说该如何做好数据库开发呢?这个上网搜了一下?看来总李多虑了!apple 提供了一种数 ...
- iOS开发之表视图爱上CoreData
在接触到CoreData时,感觉就是苹果封装的一个ORM.CoreData负责在Model的实体和sqllite建立关联,数据模型的实体类就相当于Java中的JavaBean, 而CoreData的功 ...
随机推荐
- CSS3--阴影,渐变,背景图片
文字阴影.element{ text-shadow:1px 1px 1px #cccccc;}先右再下第一个值:右侧阴影的大小第二个值:下方阴影的大小第三个值:模糊距离(阴影从开始变淡到完全消失的距离 ...
- OBIEE 简介
Oracle BIEE历史: BIEE:全称Oracle Business Intelligence Enterprise Edition. Oracle公司在05年底收购Siebel,取其前端开发工 ...
- sublime3安装
1.下载安装程序 http://c758482.r82.cf2.rackcdn.com/Sublime%20Text%20Build%203059%20Setup.exe 2.下载注册机 http:/ ...
- ios导航栏又按钮添加图片后使其保持原色
UIBarButtonItem *rightBarItem = [[UIBarButtonItem alloc] initWithTitle:nil style:UIBarButtonItemStyl ...
- linux服务器出现严重故障后的原因以及解决方法
1.把系统安装光盘插入,重启机器,启动时迅速按下Del键,进入CMOS,把启动顺序改为光盘先启动,这样就启动了Linux安装程序,按F5,按提示打入Linux rescue回车,进入救援模式,接下来是 ...
- Java编程中时区和时间相关的问题
先说一个结论:时间戳是一个和时区无关的东西,在哪里都是一致的!但是转化为字符串之后,就和时区有关系了. 以下为内容: 参考链接:http://m.blog.csdn.net/article/detai ...
- CSS3秘笈:第十二章&第十三章
第十二章 1.网页布局类型 (1)固定宽度 (2)流式 (3)响应式Web设计 2.CSS布局的方法 通过给元素设置一个宽度,将它浮到左侧或右侧,就可以创建一个列(元素后面的文本会环绕浮动的元素,仿佛 ...
- hdu_5762_Teacher Bo(鸽笼原理)
题目链接:hdu_5762_Teacher Bo 题意: 给你n个点,问你能否找到两对点的曼哈顿距离相等 题解: 最开始看到这题,看数据以为要向nlogn的复杂度发展,结果经验误导了自己,我们仔细观察 ...
- Centos中压缩(zip)和解压(unzip)命令
摘自:http://liuzhichao.com/p/681.html 1.我下载了一个yasuo.zip文件,想解压缩: # unzip yasuo.zip 2.我当前目录下有abc1.zip,ab ...
- jquery为多个元素添加事件
html <c:forEach items="${modellist}" var="model" varStatus="status" ...