标签:
一、离线缓存
1.ios中数据的存储方式
(1)Plist(NSArray\NSDictionary)
(2)Preference(偏好设置\NSUserDefaults)
(3)NSCoding(NSKeyedArchiver\NSkeyedUnarchiver)
(4)SQLite3
(5)Core Data
说明:
(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
标签:
原文地址:http://www.cnblogs.com/fengmin/p/5015743.html