iOS开发  数据库FMDB

1.简介

需求作用:  如果需要保存大量的结构较为复杂的数据时候, 使用数据库, 例如交规考试项目

常用的数据库:

  (1)Microsoft SQL Server 2000/2008, 中小企业使用较多

  (2)Oracle 比较复杂, 大企业使用较多

  (3)Mysql数据库, 网站使用较多

  (4)sqlite:  本地数据库, 访问数据足够快, 直接访问文件

         足够简单, 功能相对其他数据库软件不是特别齐全, 足够用了

          足够小, 系统不超过1M, 适合在移动端上使用

2. MesaSQlite使用

实例:  使用数据存储存储一个班上学生的信息

      学号sid  用户名username  密码password 成绩score

      1501    zhangsan      123      100

      1502    lilei         321      90

      1503    wangwu        222      80 

(1)创建数据库

(2)创建数据表

(3)设计数据表(添加多个字段/列)

(4)数据库常用操作

  增,删,改,查

3. SQL结构化查询语句

SQL, Structure Query Language, 结构化查询语言, 作用就是操作数据库(创建表, 数据增删改查)

(1)创建数据表

create table if not exists StudentInfo(sid integer,
username varchar(20),
password varchar(20),
score varchar(20))

(2)插入数据

insert into StudentInfo(sid,username,password,score) values(1501,'zhangsan','','')

(3)查询数据

<1>查询表格中所有数据

select * from StudentInfo;

<2>查询指定的字段

实例:  查询所有名字username

select username from StudentInfo

<3>根据指定的条件进行查询

实例: 查找name为zhansan的所有信息

select * from StudentInfo where username='zhangsan'

<4>根据多个条件进行查询

实例: 查找username为zhansan, 并且password为123的所有信息

select * from StudentInfo where username='zhangsan' and password=''

<5>查询后需要排序

a.根据score升序排列

select * from StudentInfo order by score

b.根据score降序
排序

select * from StudentInfo order by score desc

<6>获取数据行数

select count(*) from StudentInfo 

(4)修改数据

update StudentInfo set score=''  where username='zhangsan';

(5)删除数据

delete from StudentInfo where sid=''

4. FMDB操作数据库

配置

  导入FMDB文件,

  添加二进制库 libsqlite3.dylib,

  包含头文件#import "FMDatabase.h"

#import "ViewController.h"

#import "FMDatabase.h"

@interface ViewController (){
//创建数据库对象
FMDatabase *_database;
} @end
//1.创建数据库
-(void)createAndInitDatabase
{
//设置路径
NSString *path=[NSString stringWithFormat:@"%@/Documents/stuInfo.sqlite",NSHomeDirectory()];
//创建数据库(如果不存在则创建打开,如果存在则直接打开)
_database=[[FMDatabase alloc] initWithPath:path];
if (!_database.open) {
NSLog(@"打开失败");
return;
}
NSLog(@"打开成功");
}
//2.创建数据表
-(void)createTable
{
NSString *sql=@"create table if not exists StudentInfo(sid integer,"
"username varchar(20),"
"password varchar(20),"
"score varchar(20))";
//executeQuery用来执行select语句
//其他语句使用executeUpdate BOOL b=[_database executeUpdate:sql];
NSLog(@"----b=%d",b);
}
//3.插入数据
-(void)insertData
{
int sid=;
NSString *username=@"lisi";
NSString *password=@"";
NSString *score=@"";
NSString *sql=@"insert into StudentInfo(sid,username,password,score) values(?,?,?,?)";
//注意:?对应的每一个参数都应该是字符串,其他类型转化为字符串
BOOL b=[_database executeUpdate:sql,[NSString stringWithFormat:@"%d",sid],username,password,score ];
NSLog(@"=======b=%d",b); }
//4.查询数据
-(void)queryData
{
//显示所有人得信息
NSString *sql=@"select * from StudentInfo";
//FMResultSet 表示查询后结果集
FMResultSet *resultSet=[_database executeQuery:sql];
//next方法每次获取一条记录,获取不到的返回nil
while ([resultSet next]) {
NSLog(@"sid = %@,name =%@,pass =%@,score =%@",[resultSet stringForColumn:@"sid"],[resultSet stringForColumn:@"username"],[resultSet stringForColumn:@"password"],[resultSet stringForColumn:@"score"]);
} }
//5.修改数据
-(void)setData
{ NSString *username=@"lisi";
NSString *score=@"";
NSString *sql=@"update StudentInfo set score='60' where username='lisi';";
BOOL b=[_database executeUpdate:sql,username,score ];
NSLog(@"++++++b=%d",b); }
//6.删除数据
-(void)deleteData
{
NSString *sid=@"";
NSString *sql=@"delete from StudentInfo where sid='1501'";
BOOL b=[_database executeUpdate:sql,sid];
NSLog(@"*******b=%d",b);
}

5. 数据库在项目中使用-单例设计模式

1.首先导入FMDB文件和data.sqlite

2.添加二进制库 libsqlite3.dylib,包含头文件#import "FMDatabase.h"

3.创建一个FirstLevelModel模型,在FirstLevelModel.h里面自己定义属性,导入单例

#import <Foundation/Foundation.h>
#import "FirstLevelModel.h" @interface DatabaseManager : NSObject //获取单例对象
+(id)sharedInstance; //获取第一级目录
-(NSArray *)firstLevels;
#import "DatabaseManager.h"
#import "FMDatabase.h" @interface DatabaseManager()
{
FMDatabase *_database;
} @end @implementation DatabaseManager //获取单例对象
+(id)sharedInstance
{
static DatabaseManager *dc=nil;
if(dc==nil)
{
dc=[[[self class] alloc] init];
}
return dc;
} -(id)init
{
if (self=[super init]) {
[self openDatabase];
}
return self;
} -(void)openDatabase
{
NSString *path=[[NSBundle mainBundle] pathForResource:@"data.sqlite" ofType:nil];
_database=[[FMDatabase alloc] initWithPath:path];
if (!_database.open) {
NSLog(@"打开失败");
}
} //获取第一级目录
-(NSArray *)firstLevels
{
NSString *sql=@"select * from firstlevel";
FMResultSet *resultset=[_database executeQuery:sql];
NSMutableArray *marr=[[NSMutableArray alloc] init];
while ([resultset next]) {
FirstLevelModel *model=[[FirstLevelModel alloc] init];
model.pid=[resultset stringForColumn:@"pid"];
model.pname=[resultset stringForColumn:@"pname"];
model.pcount=[resultset stringForColumn:@"pcount"]; [marr addObject:model];
} return marr; }

自己做了一个简单“交通考试”的实例

效果图:

实现代码:点我下载

iOS开发 数据库FMDB的更多相关文章

  1. iOS开发数据库-FMDB

    前言 FMDB是以OC的方式封装了SQLite的C语言API,使用起来更加面向对象,省去了很多麻烦.冗余的C语言代码:对比苹果自带的Core Data框架,更加轻量级和灵活:提供了多线程安全的数据库操 ...

  2. iOS开发数据库篇—FMDB简单介绍

    iOS开发数据库篇—FMDB简单介绍 一.简单说明 1.什么是FMDB FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言API 2.FMDB的优点 使用起来 ...

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

    iOS开发数据库篇—FMDB数据库队列 一.代码示例 1.需要先导入FMDB框架和头文件,由于该框架依赖于libsqlite库,所以还应该导入该库. 2.代码如下: // // YYViewContr ...

  4. iOS开发数据库篇—SQLite简单介绍

    iOS开发数据库篇—SQLite简单介绍 一.离线缓存 在项目开发中,通常都需要对数据进行离线缓存的处理,如新闻数据的离线缓存等. 说明:离线缓存一般都是把数据保存到项目的沙盒中.有以下几种方式 (1 ...

  5. iOS开发数据库篇—SQL

    iOS开发数据库篇—SQL 一.SQL语句 如果要在程序运行过程中操作数据库中的数据,那得先学会使用SQL语句 1.什么是SQL SQL(structured query language):结构化查 ...

  6. iOS开发数据库篇—SQL代码应用示例

    iOS开发数据库篇—SQL代码应用示例 一.使用代码的方式批量添加(导入)数据到数据库中 1.执行SQL语句在数据库中添加一条信息 插入一条数据的sql语句: 点击run执行语句之后,刷新数据 2.在 ...

  7. iOS开发数据库篇—SQLite的应用

    iOS开发数据库篇—SQLite的应用 一.简单说明 在iOS中使用SQLite3,首先要添加库文件libsqlite3.dylib和导入主头文件. 导入头文件,可以使用库中的函数(是纯C语言的) 二 ...

  8. IOS开发数据库篇—SQLite模糊查询

    IOS开发数据库篇—SQLite模糊查询 一.示例 说明:本文简单示例了SQLite的模糊查询 1.新建一个继承自NSObject的模型 该类中的代码: // // YYPerson.h // 03- ...

  9. iOS开发数据库篇—SQLite常用的函数

    iOS开发数据库篇—SQLite常用的函数 一.简单说明 1.打开数据库 int sqlite3_open( const char *filename,   // 数据库的文件路径 sqlite3 * ...

随机推荐

  1. SDWebImage实现原理详解

    1)当需要获取网络图片的时候,我们首先需要的便是URL,如果没有URL什么都没有,获得URL后,SDWebImage实现的并不是直接去请求网路,而是检查图片缓存中有没有和URL相关的图片,如果有则直接 ...

  2. iOS_SN_深浅拷贝( 百度的)_转载

    文章原地址:http://www.cnblogs.com/5ishare/p/4362459.html 深浅拷贝前提是:是实现NSCopying或者NSMutableCopying协议. 浅拷贝只是复 ...

  3. 关于百度鹰眼中 xcode 7 编译报错问题

    请把 这个地方改为 YES 否则demo 不能运行

  4. 18 java 代理模式 (转)

    静态代理 1.新建一个接口,这个接口所提供的方法是关于数据库操作的 public interface EmployeeDao { public void updateSalary(); } 2.建一个 ...

  5. mac下升级ruby环境版本

    在ios开发中会经常使用到cocoapods来管理第三方框架,在安装cocoapods的时候会涉及到ruby环境,有时候会因为版本过低会导致安装失败,本文主要讲一下如何升级ruby环境 安装rvm,r ...

  6. sublime text 发现一个超好的编辑器

    垂直竖行多行编辑 鼠标中建拖动或 shift+右键拖动 切换文件 ctrl+p 输入文件名 可以拖动项目文件夹到sublime text左栏, 也可文件--打开文件夹--项目所在文件夹,但会在新窗口中 ...

  7. BasicExcel说明文档

    BasicExcel说明文档 BasicExcel原始链接:http://www.codeproject.com/Articles/13852/BasicExcel-A-Class-to-Read-a ...

  8. MVC过滤器详解和示例

    原文  http://blog.csdn.net/ankeyuan/article/details/29624005 MVC过滤器一共分为四个:ActionFilter(方法过滤器),ResultFi ...

  9. a标签# 和javascript:;的区别

    最近遇到一个问题,解决了记录下来. <body style="height:10000px;"> <span style="top:3000px;pos ...

  10. 关于NGINX变量的一些测试结果

    作为NGINX变量,不像正规语言那么正式. 但处理自定义和内部变量时,这些操作,也是少不了的. geo $dollar { default "$"; } server { list ...