mysql查询归档数据库_1.归档以及数据库操作

归档的操作

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

使用:遵守

- (void)encodeWithCoder:(NSCoder *)aCoder;

- (nullable instancetype)initWithCoder:(NSCoder *)aDecoder;

1.SQLite3的使用

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

5583369.html

2.导入头文件

import

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”

//1.executeUpdate:oc [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]) {

// …

}

}];

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值