码迷,mamicode.com
首页 > 数据库 > 详细

SQLite简单介绍

时间:2015-12-03 13:25:38      阅读:263      评论:0      收藏:0      [点我收藏+]

标签:

一、离线缓存

在项目开发中,通常都需要对数据进行离线缓存的处理,如新闻数据的离线缓存等。
说明:离线缓存一般都是把数据保存到项目的沙盒中。有以下几种方式
(1)归档:NSCodeing、NSKeyedArchiver
(2)偏好设置:NSUserDefaults
(3)Plist存储:writeToFile
提示:上述三种方法都有一个致命的缺点,那就是都无法存储大批量的数据,有性能的问题。
举例:使用归档
技术分享
两个问题:
(1)数据的存取都必须是完整的,要求写入的时候要一次性写入,读取的时候要一次性全部读取,这涉及到应用的性能问题。
(2)如果有1000条数据,此时要把第1001条数据存入,那么需要把所有的数据取出来,把这条数据加上去之后,再存入。
说明:以上的三种技术不能处理大批量数据的存储,大批量数据通常使用数据库来进行存储。
 
 二、SQLite简单介绍

1.ios中数据的存储方式

(1)Plist(NSArray\NSDictionary)

(2)Preference(偏好设置\NSUserDefaults)

(3)NSCoding(NSKeyedArchiver\NSkeyedUnarchiver)

(4)SQLite3

  (5)Core Data

说明:

3是版本号,是SQLite的第三个版本。
core Data是对SQLite的封装,因为iOS中使用的SQLite是纯C语言的。
2.SQLite

(1)什么是SQLite?

答:SQLite是一款轻型的嵌入式数据库,安卓和ios开发使用的都是SQLite数据库

(2)特点(优点)

  答:1)它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了

  2)它的处理速度比Mysql、PostgreSQL这两款著名的数据库都还快

(3)什么是数据库

答:数据库(Database)是按照数据结构来组织、存储和管理数据的仓库

(4)数据库的分类

答:可以分为2大种类

关系型数据库(主流)和对象型数据库(直接把内存中的对象塞入到数据库,对比关系型数据库而言性能不能很好,效率不高)

(5)常用关系型数据库有哪些?

答:PC端:Oracle、MySQL、SQL Server、Access、DB2、Sybase

  嵌入式\移动客户端:SQLite

(6)数据库是如何存储数据的?

答:数据库的存储结构和excel很像,以表(table)为单位 。表由多个字段(列、属性、column)组成,表里面的每一行数据称为记录

技术分享

(7)数据库存储数据的步骤?

1)新建一张表(table)

2)添加多个字段(column,列,属性)

3)添加多行记录(row,record,每行存放多个字段对应的值)

 

三、Navicat

Navicat是一款著名的数据库管理软件,支持大部分主流数据库(包括SQLite)

1.Navicat的安装

(1)下载该软件后,先打开该软件

技术分享

技术分享

(2)把文件拖入到应用程序拷贝

技术分享

(3)破解版,千万不要打开app,先打开sn.app

  技术分享

(4)点击patch,找到应用程序的路径,点击open.

技术分享

  技术分享

(5)点击Generate,生成注册码

技术分享

(6)点击activate,选择文件,open

技术分享

技术分享

(7)退出sn,打开安装文件,完成安装

  技术分享

2.Navicat的使用

  新建一个SQLite3数据库

技术分享

创建一个新的数据库

技术分享

设置数据库保存的位置(新建一个文件夹):

技术分享

起个名称之后,保存

技术分享

设置数据库连接的名称

  技术分享

完成之后,双击连接数据库

技术分享

注意:yangyong是连接名称,不是数据库,利用yangyong这个连接,连接了main数据库。几项依次是表、视图、索引、触发器、查询。

新建一张表,设置字段名

技术分享

保存,设置表名(建议以t开头以下划线隔开,以示区分,说明这是张表)

技术分享

 

 

 

 

iOS开发数据库篇—SQL

一、SQL语句

如果要在程序运行过程中操作数据库中的数据,那得先学会使用SQL语句

1.什么是SQL

SQL(structured query language):结构化查询语言

SQL是一种对关系型数据库中的数据进行定义和操作的语言

SQL语言简洁,语法简单,好学好用

 

2.什么是SQL语句

使用SQL语言编写出来的句子\代码,就是SQL语句

在程序运行过程中,要想操作(增删改查,CRUD)数据库中的数据,必须使用SQL语句

 

3.SQL语句的特点

不区分大小写(比如数据库认为user和UsEr是一样的)

每条语句都必须以分号 ; 结尾

 

4.SQL中的常用关键字有

select、insert、update、delete、from、create、where、desc、order、by、group、table、alter、view、index等等

数据库中不可以使用关键字来命名表、字段

 

二、SQL语句的种类

1.数据定义语句(DDL:Data Definition Language)

包括create和drop等操作

在数据库中创建新表或删除表(create table或 drop table)

 

2.数据操作语句(DML:Data Manipulation Language)

包括insert、update、delete等操作

上面的3种操作分别用于添加、修改、删除表中的数据

 

3.数据查询语句(DQL:Data Query Language)

可以用于查询获得表中的数据

关键字select是DQL(也是所有SQL)用得最多的操作

其他DQL常用的关键字有where,order by,group by和having

 

三、基本操作

1.创建表

create table 表名 (字段名1 字段类型1, 字段名2 字段类型2, …) ;

create table if not exists 表名 (字段名1 字段类型1, 字段名2 字段类型2, …) ;

示例

create table t_student (id integer, name text, age integer, score real) ;

2.字段类型

SQLite将数据划分为以下几种存储类型:

integer : 整型值

real : 浮点值

text : 文本字符串

blob : 二进制数据(比如文件)

 

注意:实际上SQLite是无类型的,就算声明为integer类型,还是能存储字符串文本(主键除外)

建表时声明啥类型或者不声明类型都可以,也就意味着创表语句可以这么写:

create table t_student(name, age);

 

提示:为了保持良好的编程规范、方便程序员之间的交流,编写建表语句的时候最好加上每个字段的具体类型

 

3.删表

格式

drop table 表名 ;

drop table if exists 表名 ;

 

示例

drop table t_student ;

 

4.插入数据(insert)

格式

insert into 表名 (字段1, 字段2, …) values (字段1的值, 字段2的值, …) ; 

示例

insert into t_student (name, age) values (‘mj’, 10) ; 

注意

数据库中的字符串内容应该用单引号 ’ 括住

 

5.更新数据(update)

格式

update 表名 set 字段1 = 字段1的值, 字段2 = 字段2的值, … ; 

示例

update t_student set name = ‘jack’, age = 20 ; 

注意

上面的示例会将t_student表中所有记录的name都改为jack,age都改为20

6.删除数据(delete)

格式

delete from 表名 ;

示例

delete from t_student ;

注意

上面的示例会将t_student表中所有记录都删掉

7.条件语句

如果只想更新或者删除某些固定的记录,那就必须在DML语句后加上一些条件

条件语句的常见格式

where 字段 = 某个值 ;   // 不能用两个 =

where 字段 is 某个值 ;   // is 相当于 = 

where 字段 != 某个值 ; 

where 字段 is not 某个值 ;   // is not 相当于 != 

where 字段 > 某个值 ; 

where 字段1 = 某个值 and 字段2 > 某个值 ;  // and相当于C语言中的 &&

where 字段1 = 某个值 or 字段2 = 某个值 ;  //  or 相当于C语言中的 ||

示例

将t_student表中年龄大于10 并且 姓名不等于jack的记录,年龄都改为 5

update t_student set age = 5 where age > 10 and name != ‘jack’ ;

 

删除t_student表中年龄小于等于10 或者 年龄大于30的记录

delete from t_student where age <= 10 or age > 30 ;

 

猜猜下面语句的作用

update t_student set score = age where name = ‘jack’ ;

将t_student表中名字等于jack的记录,score字段的值 都改为 age字段的值

8.DQL语句

格式

select 字段1, 字段2, … from 表名 ;

select * from 表名;   //  查询所有的字段

 

示例

select name, age from t_student ;

select * from t_student ;

select * from t_student where age > 10 ;  //  条件查询

 

9.起别名

格式(字段和表都可以起别名)

select 字段1 别名 , 字段2 别名 , … from 表名 别名 ; 

select 字段1 别名, 字段2 as 别名, … from 表名 as 别名 ;

select 别名.字段1, 别名.字段2, … from 表名 别名 ;

示例

select name myname, age myage from t_student ;

给name起个叫做myname的别名,给age起个叫做myage的别名

select s.name, s.age from t_student s ;

给t_student表起个别名叫做s,利用s来引用表中的字段

 

10.计算记录的数量

格式

select count (字段) from 表名 ;

select count ( * ) from 表名 ;

示例

select count (age) from t_student ;

select count ( * ) from t_student where score >= 60;

11.排序

查询出来的结果可以用order by进行排序

select * from t_student order by 字段 ;

select * from t_student order by age ;

默认是按照升序排序(由小到大),也可以变为降序(由大到小)

select * from t_student order by age desc ;  //降序

select * from t_student order by age asc ;   // 升序(默认)

也可以用多个字段进行排序

select * from t_student order by age asc, height desc ;

先按照年龄排序(升序),年龄相等就按照身高排序(降序)

 

12.limit

使用limit可以精确地控制查询结果的数量,比如每次只查询10条数据

格式

select * from 表名 limit 数值1, 数值2 ;

示例

select * from t_student limit 4, 8 ;

可以理解为:跳过最前面4条语句,然后取8条记录

limit常用来做分页查询,比如每页固定显示5条数据,那么应该这样取数据

第1页:limit 0, 5

第2页:limit 5, 5

第3页:limit 10, 5

第n页:limit 5*(n-1), 5

 

select * from t_student limit 7 ;这条语句的作用相当于select * from t_student limit 0, 7 ;表示取最前面的7条记录

 

四、约束

1.简单约束

建表时可以给特定的字段设置一些约束条件,常见的约束有

not null :规定字段的值不能为null

unique :规定字段的值必须唯一

default :指定字段的默认值

(建议:尽量给字段设定严格的约束,以保证数据的规范性)

 

示例

create table t_student (id integer, name text not null unique, age integer not null default 1) ;

name字段不能为null,并且唯一

age字段不能为null,并且默认为1

 

2.主键约束

(1)简单说明

如果t_student表中就name和age两个字段,而且有些记录的name和age字段的值都一样时,那么就没法区分这些数据,造成数据库的记录不唯一,这样就不方便管理数据

良好的数据库编程规范应该要保证每条记录的唯一性,为此,增加了主键约束

也就是说,每张表都必须有一个主键,用来标识记录的唯一性

(2)什么是主键?

主键(Primary Key,简称PK)用来唯一地标识某一条记录

例如t_student可以增加一个id字段作为主键,相当于人的身份证

主键可以是一个字段或多个字段

(3)主键的设计原则

主键应当是对用户没有意义的 

永远也不要更新主键

主键不应包含动态变化的数据

主键应当由计算机自动生成

(4)主键的声明

在创表的时候用primary key声明一个主键

create table t_student (id integer primary key, name text, age integer) ;

integer类型的id作为t_student表的主键

 

主键字段

只要声明为primary key,就说明是一个主键字段

主键字段默认就包含了not null 和 unique 两个约束

 

说明:如果想要让主键自动增长(必须是integer类型),应该增加autoincrement

create table t_student (id integer primary key autoincrement, name text, age integer) ;

 

3.外键约束

利用外键约束可以用来建立表与表之间的联系

外键的一般情况是:一张表的某个字段,引用着另一张表的主键字段

新建一个外键

create table t_student (id integer primary key autoincrement, name text, age integer, class_id integer, constraint fk_student_class foreign key (class_id) references t_class (id));

t_student表中有一个叫做fk_t_student_class_id_t_class_id的外键

这个外键的作用是用t_student表中的class_id字段引用t_class表的id字段

 

4.表连接查询

表连接查询:需要联合多张表才能查到想要的数据

表连接的类型

内连接:inner join 或者 join  (显示的是左右表都有完整字段值的记录)

左外连接:left outer join (保证左表数据的完整性) 

示例

查询0316iOS班的所有学生

select s.name,s.age from t_student s, t_class c where s.class_id = c.id and c.name = ‘0316iOS’;

 

 
 
 
 
 

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

一、使用代码的方式批量添加(导入)数据到数据库中

1.执行SQL语句在数据库中添加一条信息

技术分享

插入一条数据的sql语句:

  技术分享

点击run执行语句之后,刷新数据

技术分享

2.在ios项目中使用代码批量添加多行数据示例

  代码示例:

技术分享
 1 //
 2 //  main.m
 3 //  01-为数据库添加多行数据
 4 //
 5 //  Created by apple on 14-7-26.
 6 //  Copyright (c) 2014年 wendingding. All rights reserved.
 7 //
 8 
 9 #import <Foundation/Foundation.h>
10 
11 int main(int argc, const char * argv[])
12 {
13 
14     @autoreleasepool {
15         NSArray *names=@[@"张一",@"张二",@"张三",@"张四"];
16         NSMutableString *sql=[NSMutableString string];
17         
18         for (int i=0; i<200; i++) {
19             int ID=i+1;
20             //这里的警告为无符号类型转换
21             NSString *name=names[arc4random_uniform(names.count)];
22             name=[name stringByAppendingFormat:@"-%d",arc4random_uniform(200)];
23             //生成随机数,范围以20为中心上下波动10
24             int age=arc4random_uniform(20)+10;
25             [sql appendFormat:@"INSERT INTO t_student (id,name,age) VALUES (%d,‘%@‘,%d);\n",ID,name,age];
26         }
27         //把sql写入到文件中
28         [sql writeToFile:@"/Users/apple/Desk/students.sql" atomically:YES encoding:NSUTF8StringEncoding error:nil];
29         NSLog(@"\n%@",sql);
30         }
31     return 0;
32 }
技术分享

作用:生成200条相应的sql插入语句

打印结果为:

技术分享

使用文本编辑器,打开生成的sql文件。

技术分享

可以把这些SQL语句拷贝到Navicat中进行执行,也可以直接执行整个文件。

在数据库中创建一张表:

技术分享

选择执行SQL文件:

技术分享   技术分享 

执行完毕后,点击cancel。

技术分享

刷新数据库,查看插入的200条数据

技术分享

 

二、分页简单演示

技术分享

说明:

使用limit可以精确地控制查询结果的数量,比如每次只查询10条数据

格式 select * from 表名 limit 数值1, 数值2 ;

示例

select * from t_student limit 4, 8 ;

可以理解为:跳过最前面4条语句,然后取8条记录

limit常用来做分页查询,比如每页固定显示5条数据,那么应该这样取数据

第1页:limit 0, 5

第2页:limit 5, 5

第3页:limit 10, 5

第n页:limit 5*(n-1), 5

 

下面语句的作用

select * from t_student limit 7 ;

相当于select * from t_student limit 0, 7 ;表示取最前面的7条记录

 

三、补充

1.关于外键约束(建立起两张表之间的联系)

第一种做法:可以新建一张关系表,让之前两张表(班级表和学生表建立起对应的联系),但是这种做法很冗余,没有必要

技术分享

第二种做法:使用外键约束

一对一,一对多,多对多关系。当两张表有联系时,如何设置外键(在哪张表中设置?)

技术分享

技术分享

 

2.关于表连接

子查询:要求查询所有类型为粤菜的菜名。

技术分享

查询结果为:

技术分享

连接查询:

技术分享

查询结果为:

技术分享

 

 

 

 

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

一、简单说明

  在iOS中使用SQLite3,首先要添加库文件libsqlite3.dylib和导入主头文件。

  技术分享

技术分享

导入头文件,可以使用库中的函数(是纯C语言的)

技术分享

 

二、具体说明

新建一个项目,在项目的主界面中放四个按钮(分别是,增加、删除、修改、查询)。

技术分享

1.sqlite3_open(<#const char *filename#>, <#sqlite3 **ppDb#>)函数的一些说明:

技术分享

(1)作用:把一个文件名称传递给他,它会自动检测这个文件是否存在,如果不存在的话,会自动创建相应的文件(这里为数据库文件,刚创建为空)。

(2)参数:它的第一个参数为文件的名称(需转换为C语言的),第二个参数是数据库的实例,sqlite3 *db;

  说明:sqlite3是一种类型,db是数据库的句柄,就是数据库的象征,如果要进行增删改查,就得操作db这个实例。

(3)返回值:它的返回值为int型的,根据函数的返回值可以知道,打开数据库文件是成功还是失败,如果返回值是SQLITE_OK则说明成功,否则为失败。

2.打开数据库

  实现代码和显示:

技术分享

查看沙盒内创建的数据库文件:

  技术分享

双击打开,查看发现打开的数据库连接名称为students,默认为文件名的前缀,数据库创建成功。

  技术分享

3.创建表

  函数说明:

  技术分享

  参数:第一个参数为数据库的句柄(db),第二个参数为sql语句,第三个参数为回调参数,是一个指向函数的指针,如果把callback前面的*改成^则就是一个block代码段,第四个参数可以写NULL,第五个参数为错误信息,用以代码调试。

技术分享
 1     //1.打开数据库文件(如果数据库文件不存在,那么该函数会自动创建数据库文件)
 2     int result = sqlite3_open(cfileName, &db);
 3     if (result==SQLITE_OK) {        //打开成功
 4         NSLog(@"成功打开数据库");
 5         
 6     //2.创建表
 7         const char  *sql="CREATE TABLE IF NOT EXISTS t_students (id integer PRIMARY KEY AUTOINCREMENT,name text NOT NULL,age integer NOT NULL);";
 8         char *errmsg=NULL;
 9         result = sqlite3_exec(db, sql, NULL, NULL, &errmsg);
10         if (result==SQLITE_OK) {
11             NSLog(@"创表成功");
12         }else
13         {
14             NSLog(@"创表失败----%s",errmsg);
15         }
16     }else
17     {
18         NSLog(@"打开数据库失败");
19     }
技术分享

  执行后,创表成功,打开创建的表查看:

技术分享

调试技巧:

技术分享
1    if (result==SQLITE_OK) {
2             NSLog(@"创表成功");
3         }else
4         {
5 //            NSLog(@"创表失败----%s",errmsg);
6             printf("创表失败---%s----%s---%d",errmsg,__FILE__,__LINE__);
7         }
技术分享

  __FILE__宏打印文件名,

  __LINE__宏打印行号。

  技术分享

4.插入数据

  实现代码:

技术分享
 1 - (IBAction)insert {
 2     for (int i=0; i<20; i++) {
 3         //1.拼接SQL语句
 4         NSString *name=[NSString stringWithFormat:@"文晓--%d",arc4random_uniform(100)];
 5         int age=arc4random_uniform(20)+10;
 6         NSString *sql=[NSString stringWithFormat:@"INSERT INTO t_students (name,age) VALUES (‘%@‘,%d);",name,age];
 7         
 8         //2.执行SQL语句
 9         char *errmsg=NULL;
10         sqlite3_exec(self.db, sql.UTF8String, NULL, NULL, &errmsg);
11         if (errmsg) {//如果有错误信息
12             NSLog(@"插入数据失败--%s",errmsg);
13         }else
14         {
15             NSLog(@"插入数据成功");
16         }
17     }
18 }
技术分享

  打印查看:

技术分享

查看数据库里t_students表中的数据:

技术分享

 

5.选择(select)查询操作

  函数说明:

  select操作也可以使用sqlite3_exec函数实现,但通常使用下面的函数。

  技术分享

  参数:第一个参数为数据库的句柄,第二个参数为sql语句,第三个参数为sql的长度(如果设置为-1,则代表系统会自动计算sql语句的长度),第四个参数用来取数据,第五个参数为尾部一般用不上可直接写NULL。

  示例代码:

技术分享
 1 - (IBAction)select {
 2     const char *sql="SELECT id,name,age FROM t_students WHERE age<20;";
 3     sqlite3_stmt *stmt=NULL;
 4     
 5     //进行查询前的准备工作
 6     if (sqlite3_prepare_v2(self.db, sql, -1, &stmt, NULL)==SQLITE_OK) {//SQL语句没有问题
 7         NSLog(@"查询语句没有问题");
 8         
 9         //每调用一次sqlite3_step函数,stmt就会指向下一条记录
10         while (sqlite3_step(stmt)==SQLITE_ROW) {//找到一条记录
11             //取出数据
12             //(1)取出第0列字段的值(int类型的值)
13             int ID=sqlite3_column_int(stmt, 0);
14             //(2)取出第1列字段的值(text类型的值)
15             const unsigned char *name=sqlite3_column_text(stmt, 1);
16             //(3)取出第2列字段的值(int类型的值)
17             int age=sqlite3_column_int(stmt, 2);
18 //            NSLog(@"%d %s %d",ID,name,age);
19             printf("%d %s %d\n",ID,name,age);
20         }
21     }else
22     {
23         NSLog(@"查询语句有问题");
24     }
25     
26 }
技术分享

  打印查看查询结果:

技术分享

三、补充

  完整代码:

   YYViewController.m文件

技术分享
  1 //
  2 //  YYViewController.m
  3 //  02-SQLite的应用
  4 //
  5 
  6 #import "YYViewController.h"
  7 #import <sqlite3.h>
  8 
  9 @interface YYViewController ()
 10   //db是数据库的句柄,就是数据库的象征,要对数据库进行增删改查,就得操作这个实例
 11 @property(nonatomic,assign)sqlite3 *db;
 12 - (IBAction)insert;
 13 - (IBAction)delete;
 14 - (IBAction)update;
 15 - (IBAction)select;
 16 
 17 @end
 18 
 19 @implementation YYViewController
 20 
 21 - (void)viewDidLoad
 22 {
 23     [super viewDidLoad];
 24     
 25 //    sqlite3 *db;
 26     
 27     //获得数据库文件的路径
 28     NSString *doc=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
 29     NSString *fileName=[doc stringByAppendingPathComponent:@"students.sqlite"];
 30     //将OC字符串转换为c语言的字符串
 31     const char *cfileName=fileName.UTF8String;
 32     
 33     //1.打开数据库文件(如果数据库文件不存在,那么该函数会自动创建数据库文件)
 34     int result = sqlite3_open(cfileName, &_db);
 35     if (result==SQLITE_OK) {        //打开成功
 36         NSLog(@"成功打开数据库");
 37         
 38     //2.创建表
 39         const char  *sql="CREATE TABLE  t_students (id integer PRIMARY KEY AUTOINCREMENT,name text NOT NULL,age integer NOT NULL);";
 40         char *errmsg=NULL;
 41         result = sqlite3_exec(self.db, sql, NULL, NULL, &errmsg);
 42         if (result==SQLITE_OK) {
 43             NSLog(@"创表成功");
 44         }else
 45         {
 46 //            NSLog(@"创表失败----%s",errmsg);
 47             printf("创表失败---%s----%s---%d",errmsg,__FILE__,__LINE__);
 48         }
 49     }else
 50     {
 51         NSLog(@"打开数据库失败");
 52     }
 53 }
 54 
 55 - (IBAction)insert {
 56     for (int i=0; i<20; i++) {
 57         //1.拼接SQL语句
 58         NSString *name=[NSString stringWithFormat:@"文晓--%d",arc4random_uniform(100)];
 59         int age=arc4random_uniform(20)+10;
 60         NSString *sql=[NSString stringWithFormat:@"INSERT INTO t_students (name,age) VALUES (‘%@‘,%d);",name,age];
 61         
 62         //2.执行SQL语句
 63         char *errmsg=NULL;
 64         sqlite3_exec(self.db, sql.UTF8String, NULL, NULL, &errmsg);
 65         if (errmsg) {//如果有错误信息
 66             NSLog(@"插入数据失败--%s",errmsg);
 67         }else
 68         {
 69             NSLog(@"插入数据成功");
 70         }
 71     }
 72 }
 73 
 74 - (IBAction)delete {
 75 }
 76 
 77 - (IBAction)updata {
 78 }
 79 
 80 - (IBAction)select {
 81     const char *sql="SELECT id,name,age FROM t_students WHERE age<20;";
 82     sqlite3_stmt *stmt=NULL;
 83     
 84     //进行查询前的准备工作
 85     if (sqlite3_prepare_v2(self.db, sql, -1, &stmt, NULL)==SQLITE_OK) {//SQL语句没有问题
 86         NSLog(@"查询语句没有问题");
 87         
 88         //每调用一次sqlite3_step函数,stmt就会指向下一条记录
 89         while (sqlite3_step(stmt)==SQLITE_ROW) {//找到一条记录
 90             //取出数据
 91             //(1)取出第0列字段的值(int类型的值)
 92             int ID=sqlite3_column_int(stmt, 0);
 93             //(2)取出第1列字段的值(text类型的值)
 94             const unsigned char *name=sqlite3_column_text(stmt, 1);
 95             //(3)取出第2列字段的值(int类型的值)
 96             int age=sqlite3_column_int(stmt, 2);
 97 //            NSLog(@"%d %s %d",ID,name,age);
 98             printf("%d %s %d\n",ID,name,age);
 99         }
100     }else
101     {
102         NSLog(@"查询语句有问题");
103     }
104     
105 }
106 @end
技术分享
 
 
 
 
 
 
 
 
 

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

一、示例

说明:本文简单示例了SQLite的模糊查询

1.新建一个继承自NSObject的模型

技术分享

该类中的代码:

技术分享
 1 //
 2 //  YYPerson.h
 3 //  03-模糊查询
 4 //
 5 //  Created by apple on 14-7-27.
 6 //  Copyright (c) 2014年 wendingding. All rights reserved.
 7 //
 8 
 9 #import <Foundation/Foundation.h>
10 
11 @interface YYPerson : NSObject
12 @property (nonatomic, assign) int ID;
13 @property (nonatomic, copy) NSString *name;
14 @property (nonatomic, assign) int age;
15 
16 @end
技术分享

2.新建一个工具类,用来管理模型

技术分享

工具类中的代码设计如下:

YYPersonTool.h文件

技术分享
 1 //
 2 //  YYPersonTool.h
 3 //  03-模糊查询
 4 //
 5 //  Created by apple on 14-7-27.
 6 //  Copyright (c) 2014年 wendingding. All rights reserved.
 7 //
 8 
 9 #import <Foundation/Foundation.h>
10 
11 @class YYPerson;
12 @interface YYPersonTool : NSObject
13 /**
14  *  保存一个联系人
15  */
16 + (void)save:( YYPerson*)person;
17 
18 /**
19  *  查询所有的联系人
20  */
21 + (NSArray *)query;
22 + (NSArray *)queryWithCondition:(NSString *)condition;
23 @end
技术分享

YYPersonTool.m文件

技术分享
  1 //
  2 //  YYPersonTool.m
  3 //  03-模糊查询
  4 //
  5 //  Created by apple on 14-7-27.
  6 //  Copyright (c) 2014年 wendingding. All rights reserved.
  7 //
  8 
  9 #import "YYPersonTool.h"
 10 #import "YYPerson.h"
 11 
 12 #import <sqlite3.h>
 13 @interface YYPersonTool ()
 14 //@property(nonatomic,assign)sqlite3 *db;
 15 @end
 16 @implementation YYPersonTool
 17 
 18 static sqlite3 *_db;
 19 //首先需要有数据库
 20 +(void)initialize
 21 {
 22     //获得数据库文件的路径
 23     NSString *doc=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
 24     NSString *fileName=[doc stringByAppendingPathComponent:@"person.sqlite"];
 25     //将OC字符串转换为c语言的字符串
 26     const char *cfileName=fileName.UTF8String;
 27     
 28     //1.打开数据库文件(如果数据库文件不存在,那么该函数会自动创建数据库文件)
 29     int result = sqlite3_open(cfileName, &_db);
 30     if (result==SQLITE_OK) {        //打开成功
 31         NSLog(@"成功打开数据库");
 32         
 33         //2.创建表
 34         const char  *sql="CREATE TABLE IF NOT EXISTS t_person (id integer PRIMARY KEY AUTOINCREMENT,name text NOT NULL,age integer NOT NULL);";
 35         
 36         char *errmsg=NULL;
 37         result = sqlite3_exec(_db, sql, NULL, NULL, &errmsg);
 38         if (result==SQLITE_OK) {
 39             NSLog(@"创表成功");
 40         }else
 41         {
 42             printf("创表失败---%s",errmsg);
 43         }
 44     }else
 45     {
 46         NSLog(@"打开数据库失败");
 47     }
 48 
 49 }
 50 //保存一条数据
 51 +(void)save:(YYPerson *)person
 52 {
 53     //1.拼接SQL语句
 54 
 55     NSString *sql=[NSString stringWithFormat:@"INSERT INTO t_person (name,age) VALUES (‘%@‘,%d);",person.name,person.age];
 56     
 57     //2.执行SQL语句
 58     char *errmsg=NULL;
 59     sqlite3_exec(_db, sql.UTF8String, NULL, NULL, &errmsg);
 60     if (errmsg) {//如果有错误信息
 61         NSLog(@"插入数据失败--%s",errmsg);
 62     }else
 63     {
 64         NSLog(@"插入数据成功");
 65     }
 66 
 67 }
 68 
 69 +(NSArray *)query
 70 {
 71     return [self queryWithCondition:@""];
 72 }
 73 
 74 //模糊查询
 75 +(NSArray *)queryWithCondition:(NSString *)condition
 76 {
 77     
 78     //数组,用来存放所有查询到的联系人
 79     NSMutableArray *persons=nil;
 80     /*
 81      [NSString stringWithFormat:@"SELECT id, name, age FROM t_person WHERE name like ‘%%%@%%‘ ORDER BY age ASC;", condition];
 82     NSString *NSsql=[NSString stringWithFormat:@"SELECT id,name,age FROM t_person WHERE name=%@;",condition];
 83     */
 84     NSString *NSsql=[NSString stringWithFormat:@"SELECT id,name,age FROM t_person WHERE name like ‘%%%@%%‘ ORDER BY age ASC;",condition];
 85     NSLog(@"%@",NSsql);
 86     const char *sql=NSsql.UTF8String;
 87     
 88     sqlite3_stmt *stmt=NULL;
 89     
 90     //进行查询前的准备工作
 91     if (sqlite3_prepare_v2(_db, sql, -1, &stmt, NULL)==SQLITE_OK) {//SQL语句没有问题
 92         NSLog(@"查询语句没有问题");
 93         
 94         persons=[NSMutableArray array];
 95         
 96         //每调用一次sqlite3_step函数,stmt就会指向下一条记录
 97         while (sqlite3_step(stmt)==SQLITE_ROW) {//找到一条记录
 98             
 99             //取出数据
100             //(1)取出第0列字段的值(int类型的值)
101             int ID=sqlite3_column_int(stmt, 0);
102             //(2)取出第1列字段的值(text类型的值)
103             const unsigned char *name=sqlite3_column_text(stmt, 1);
104             //(3)取出第2列字段的值(int类型的值)
105             int age=sqlite3_column_int(stmt, 2);
106             
107             YYPerson *p=[[YYPerson alloc]init];
108             p.ID=ID;
109             p.name=[NSString stringWithUTF8String:(const char *)name];
110             p.age=age;
111          //   NSLog(@"%@",p.name);
112             [persons addObject:p];
113          //   NSLog(@"haha%@",persons);
114         }
115     }else
116     {
117         NSLog(@"查询语句有问题");
118     }
119     
120     //NSLog(@"haha%@",persons);
121     return persons;
122 }
123 @end
技术分享

3.在storyboard中,删除原有的控制器,放一个导航控制器和UITableViewController控制器,并关联

技术分享

在代码中,让主控制器直接继承自UITableViewController

代码设计如下:

YYViewController.m文件

技术分享
 1 //
 2 //  YYViewController.m
 3 //  03-模糊查询
 4 //
 5 //  Created by apple on 14-7-27.
 6 //  Copyright (c) 2014年 wendingding. All rights reserved.
 7 //
 8 
 9 #import "YYViewController.h"
10 #import "YYPerson.h"
11 #import "YYPersonTool.h"
12 
13 @interface YYViewController ()<UISearchBarDelegate>
14 
15 //添加一个数组,用来保存person
16 @property(nonatomic,strong)NSArray *persons;
17 @end
18 
19 @implementation YYViewController
20 
21 #pragma mark-懒加载
22 -(NSArray *)persons
23 {
24     if (_persons==nil) {
25         _persons=[YYPersonTool query];
26     }
27     return _persons;
28 }
29 
30 //1.在初始化方法中添加一个搜索框
31 - (void)viewDidLoad
32 {
33     [super viewDidLoad];
34     
35     //设置搜索框
36     UISearchBar *search=[[UISearchBar alloc]init];
37     search.frame=CGRectMake(0, 0, 300, 44);
38     search.delegate=self;
39     self.navigationItem.titleView=search;
40 }
41 
42 //2.设置tableView的数据
43 //设置有多少行数据
44 -(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
45 {
46 //    return 10;
47     return self.persons.count;
48 }
49 -(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
50 {
51     //1.去缓存中取cll,若没有则自己创建并标记
52     static NSString *ID=@"ID";
53     UITableViewCell *cell=[tableView dequeueReusableCellWithIdentifier:ID];
54     if (cell==nil) {
55         cell=[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:ID];
56     }
57     
58     //2.设置每个cell的数据
59     //先取出数据模型
60     YYPerson *person=self.persons[indexPath.row];
61     //设置这个cell的姓名(name)和年龄
62     cell.textLabel.text=person.name;
63     cell.detailTextLabel.text=[NSString stringWithFormat:@"年龄  %d",person.age];
64     //3.返回cell
65     return cell;
66 }
67 
68 - (IBAction)add:(UIBarButtonItem *)sender {
69     // 初始化一些假数据
70     NSArray *names = @[@"西门抽血", @"西门抽筋", @"西门抽风", @"西门吹雪", @"东门抽血", @"东门抽筋", @"东门抽风", @"东门吹雪", @"北门抽血", @"北门抽筋", @"南门抽风", @"南门吹雪"];
71     for (int i = 0; i<20; i++) {
72         YYPerson *p = [[YYPerson alloc] init];
73         p.name = [NSString stringWithFormat:@"%@-%d", names[arc4random_uniform(names.count)], arc4random_uniform(100)];
74         p.age = arc4random_uniform(20) + 20;
75         [YYPersonTool save:p];
76     }
77 }
78 
79 #pragma mark-搜索框的代理方法
80 -(void)searchBar:(UISearchBar *)searchBar textDidChange:(NSString *)searchText
81 {
82     self.persons=[YYPersonTool queryWithCondition:searchText];
83     //刷新表格
84     [self.tableView reloadData];
85     [searchBar resignFirstResponder];
86 }
87 
88 @end
技术分享

实现效果:

  技术分享   技术分享

二、简单说明

关于:  NSString *NSsql=[NSString stringWithFormat:@"SELECT id,name,age FROM t_person WHERE name like ‘%%%@%%‘ ORDER BY age ASC;",condition];
 
注意:name like ‘西门’,相当于是name = ‘西门’。
name like ‘%西%’,为模糊搜索,搜索字符串中间包含了’西’,左边可以为任意字符串,右边可以为任意字符串,的字符串。
但是在 stringWithFormat:中%是转义字符,两个%才表示一个%。
打印查看:
技术分享
 
 
 
 
 
 
 
 

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

一、简单说明

1.打开数据库

int sqlite3_open(

    const char *filename,   // 数据库的文件路径

    sqlite3 **ppDb          // 数据库实例

);

 

2.执行任何SQL语句

int sqlite3_exec(

    sqlite3*,                                  // 一个打开的数据库实例

    const char *sql,                           // 需要执行的SQL语句

    int (*callback)(void*,int,char**,char**),  // SQL语句执行完毕后的回调

    void *,                                    // 回调函数的第1个参数

    char **errmsg                              // 错误信息

);

 

3.检查SQL语句的合法性(查询前的准备)

int sqlite3_prepare_v2(

    sqlite3 *db,            // 数据库实例

    const char *zSql,       // 需要检查的SQL语句

    int nByte,              // SQL语句的最大字节长度

    sqlite3_stmt **ppStmt,  // sqlite3_stmt实例,用来获得数据库数据

    const char **pzTail

);

 

4.查询一行数据

int sqlite3_step(sqlite3_stmt*); // 如果查询到一行数据,就会返回SQLITE_ROW

 

5.利用stmt获得某一字段的值(字段的下标从0开始)

double sqlite3_column_double(sqlite3_stmt*, int iCol);  // 浮点数据

int sqlite3_column_int(sqlite3_stmt*, int iCol); // 整型数据

sqlite3_int64 sqlite3_column_int64(sqlite3_stmt*, int iCol); // 长整型数据

const void *sqlite3_column_blob(sqlite3_stmt*, int iCol); // 二进制文本数据

const unsigned char *sqlite3_column_text(sqlite3_stmt*, int iCol);  // 字符串数据

 

二、SQLite编码

1.创建、打开、关闭数据库

创建或打开数据库

// path是数据库文件的存放路径

sqlite3 *db = NULL;

int result = sqlite3_open([path UTF8String], &db); 

 

代码解析:

sqlite3_open()将根据文件路径打开数据库,如果不存在,则会创建一个新的数据库。如果result等于常量SQLITE_OK,则表示成功打开数据库

sqlite3 *db:一个打开的数据库实例

数据库文件的路径必须以C字符串(而非NSString)传入

 

关闭数据库:sqlite3_close(db);

 

2.执行不返回数据的SQL语句

执行创表语句

char *errorMsg = NULL;  // 用来存储错误信息

char *sql = "create table if not exists t_person(id integer primary key autoincrement, name text, age integer);";

int result = sqlite3_exec(db, sql, NULL, NULL, &errorMsg);

 

代码解析:

sqlite3_exec()可以执行任何SQL语句,比如创表、更新、插入和删除操作。但是一般不用它执行查询语句,因为它不会返回查询到的数据

sqlite3_exec()还可以执行的语句:

(1)开启事务:begin transaction;

(2)回滚事务:rollback;

(3)提交事务:commit;

 

3.带占位符插入数据

char *sql = "insert into t_person(name, age) values(?, ?);";

sqlite3_stmt *stmt;

if (sqlite3_prepare_v2(db, sql, -1, &stmt, NULL) == SQLITE_OK) {

    sqlite3_bind_text(stmt, 1, "母鸡", -1, NULL);

    sqlite3_bind_int(stmt, 2, 27);

}

if (sqlite3_step(stmt) != SQLITE_DONE) {

    NSLog(@"插入数据错误");

}

sqlite3_finalize(stmt);

 

代码解析:

sqlite3_prepare_v2()返回值等于SQLITE_OK,说明SQL语句已经准备成功,没有语法问题

sqlite3_bind_text():大部分绑定函数都只有3个参数

(1)第1个参数是sqlite3_stmt *类型

(2)第2个参数指占位符的位置,第一个占位符的位置是1,不是0

(3)第3个参数指占位符要绑定的值

(4)第4个参数指在第3个参数中所传递数据的长度,对于C字符串,可以传递-1代替字符串的长度

(5)第5个参数是一个可选的函数回调,一般用于在语句执行后完成内存清理工作

sqlite_step():执行SQL语句,返回SQLITE_DONE代表成功执行完毕

sqlite_finalize():销毁sqlite3_stmt *对象

 

4.查询数据

char *sql = "select id,name,age from t_person;";

sqlite3_stmt *stmt;

if (sqlite3_prepare_v2(db, sql, -1, &stmt, NULL) == SQLITE_OK) {

    while (sqlite3_step(stmt) == SQLITE_ROW) {

        int _id = sqlite3_column_int(stmt, 0);

        char *_name = (char *)sqlite3_column_text(stmt, 1);

        NSString *name = [NSString stringWithUTF8String:_name];

        int _age = sqlite3_column_int(stmt, 2);

        NSLog(@"id=%i, name=%@, age=%i", _id, name, _age);

    }

}

sqlite3_finalize(stmt);

代码解析:

sqlite3_step()返回SQLITE_ROW代表遍历到一条新记录

sqlite3_column_*()用于获取每个字段对应的值,第2个参数是字段的索引,从0开始

 

 

 

 

 

 

SQLite简单介绍

标签:

原文地址:http://www.cnblogs.com/fengmin/p/5015743.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!