归档的操作

作用:主要用于自定义对象的持久化

使用:遵守<NSCoding协议>

-

(void)encodeWithCoder:(NSCoder *)aCoder;
  - (nullable instancetype)initWithCoder:(NSCoder *)aDecoder;

1.SQLite3的使用

1、要使用SQLite3,先要添加库文件 libsqlite3.dylib 

2.导入头文件

import<sqlite3.h>

 

2.FMDB的介绍

1.FMDB是iOS平台的SQLite数据库框架,以OC的方式封装了SQLite的C语言API,使用起来比单纯调用SQLite语句方便

2.FMDB使用起来更加面向对象,省去了很多麻烦、冗余的C语言代码

3.对比苹果自带的Core Data框架,更加轻量级灵活

4.提供了多线程安全的数据库操作方法,有效地防止数据混乱

 

如果要使用FMDB

import "FMDB.h"

3.核心三大类

  • FMDatabase(创建、删除)
  • 一个FMDatabase对象就代表一个单独的SQLite数据库
  • 用来执行SQL语句
  • FMResultSet(用来查询)
  • 使用FMDatabase执行查询后的结果集
  • FMDatabaseQueue
  • 用于在多线程中执行多个查询或更新,它是线程安全的

 

 

 

 

4.使用步骤

(1) 打开数据库

 

1.通过指定SQLite数据库文件路径来创建FMDatabase对象
 FMDatabase *db = [FMDatabase databaseWithPath:path];
 if ([db open]) {
 // 数据库打开成功
 }
2.使用实例:
 // 1.获得数据库文件的路径
 NSString *doc =[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
 // 2.拼接文件名
 NSString *filename = [doc stringByAppendingPathComponent:@"status.sqlite"]; 
 
 // 3.得到数据库
 _db = [FMDatabase databaseWithPath:filename];
 
 // 4.打开数据库 .使用如下语句,如果打开失败,可能是权限不足或者资源不足。通常打开完操作操作后,需要调用 close 方法来关闭数据库。在和数据库交互 之前,数据库必须是打开的。如果资源或权限不足无法打开或创建数据库,都会导致打开失败。
 
 if ([_db open]) {
 // 5.创建表格
 BOOL result = [_db executeUpdate:@"CREATE TABLE IF NOT EXISTS t_home_status (id integer PRIMARY KEY AUTOINCREMENT, access_token text NOT NULL, status_idstr text NOT NULL, status_dict blob NOT NULL);"];
 if (result) {
 NSLog(@"成功创表");
 } else {
 NSLog(@"创表失败");
 }

NULL: 表示该值为NULL值。

INTEGER: 无符号整型值。

REAL: 浮点值。

TEXT: 文本字符串,存储使用的编码方式为UTF-8、UTF-16BE、UTF-16LE。

BLOB: 存储Blob数据,该类型数据和输入数据完全相同。

 

3.路径设置:

1.如果设置的路径不存在,则会自动创建

2.如果为@""或者nil,则会在temp文件中创建一个空的数据库,当数据库关闭时,数据库文件也会被删除

(2) 执行插入

使用FMDataBase类执行数据库插入命令SQL“insert into”

[self.db executeUpdate:@“INSERT INTO t_student (name, age) VALUES (?,?);”,name,@(age)];
 
 //2.executeUpdateWithForamat:不确定的参数用%@,%d等来占位 (参数为原始数据类型,执行语句不区分大小写)
 [self.db executeUpdateWithForamat:@“insert into t_student (name,age) values (%@,%i);”,name,age];
 
 //3.参数是数组的使用方式
 int age = 18;
 [self.db executeUpdate:@“INSERT INTO t_student(name,age) VALUES  (?,?);”withArgumentsInArray:@[name,@(age)]];

 

(3) 执行删除

使用FMDataBase类执行数据库删除命令SQL“delete”

 

//1.不确定的参数用?来占位 (后面参数必须是oc对象,需要将int包装成OC对象)
 int idNum = 101;
 [self.db executeUpdate:@“delete from t_student where id = ?;”,@(idNum)];
 //2.不确定的参数用%@,%d等来占位
 [self.db executeUpdateWithFormat:@“ t_student = %@;”,@“apple_name”];

(4)执行更新

简单来说,只要不是以SELECT开头的命令都是更新命令。

1.CREATE,DROP,INSERT,UPDATE,DELETE等除了查询以外的操作,都称为更新操作

 

2.使用executeUpdate:方法做更新操作

  • -(BOOL)executeUpdate:(NSString*)sql, ...
  • -(BOOL)executeUpdateWithFormat:(NSString*)format, ...
  • -(BOOL)executeUpdate:(NSString)sql withArgumentsInArray:(NSArray )arguments
  • 在SQL字符串中写SQL语句
  • 执行更新返回一个BOOL值。YES表示 执行成功,否则表示有错误。你可以调用 -lastErrorMessage 和 -lastErrorCode方法来得到更多信息。
  • 3.使用示例

[db executeUpdate:@"UPDATE t_student_classtwo SET age = ? WHERE name = ?;", @"18", @"stu"]

 

(5) 执行查询

1.执行数据库查询的方法:(查询使用FMResultSet对象)

SELECT命令就是查询,执行查询的方法是以-excuteQuery开头的。

  • 执行查询时,如果成功返回FMResultSet对象,错误返回nil。与执行更新相当,支持使用NSError参数。

 

• -(FMResultSet )executeQuery:(NSString )sql, ...
• -(FMResultSet )executeQueryWithFormat:(NSString)format, ...
• -(FMResultSet )executeQuery:(NSString )sql withArgumentsInArray:(NSArray *)arguments
• 用 FMResultSet 对象的 next 方法来遍历查询到的数据

FMResultSet获取不同数据格式的方法

  • intForColumn:
  • longForColumn:
  • longLongIntForColumn: 
  • boolForColumn:
  • doubleForColumn:
  • stringForColumn:
  • dataForColumn:
  • dataNoCopyForColumn:
  • UTF8StringForColumnIndex: 
  • objectForColumn:

 

 

2.使用示例

FMResultSet *resultSet = [self.db execute Query:@“select * from t_student;”];
 
 //根据条件查询
 FMResultSet *resultSet = [self.db executeQuery:@“select * from t_student where id<?;”@(14)];
 
 //排序查询
 [_db executeQuery:@"select * from t_Student ORDER BY age DESC"] ,这个是通过age字段 降序排序 升序就是不写DESC
 
 //遍历结果集合   
 
 while ([resultSet  next])
 {
 int idNum = [resultSet intForColumn:@“id”];
 NSString *name = [resultSet objectForColumn:@“name”];
 int age = [resultSet intForColumn:@“age”];
 }

(6) 数据库删除

 

使用FMDataBase类执行数据库销毁命令SQLdrop ...

 

//   [self.db executeUpadate:@“drop table if exists t_student;”];

 

(7) 线程安全的数据库

为了保证线程安全,FMDB提供方便快捷的FMDatabaseQueue

示例:

queue = [FMDatabaseQueue databaseQueueWithPath:path];
 [db executeUpdate:@"INSERT INTO t_student(name) VALUES (?)", @"stu1"];
 [db executeUpdate:@"INSERT INTO t_student(name) VALUES (?)", @"stu2"];
 [db executeUpdate:@"INSERT INTO t_student(name) VALUES (?)", @"stu3"];
 FMResultSet *results = [db executeQuery:@"select * from t_student"];
 while ([results next]) {
 // …
 }
 }];