一、SQLite 简介
SQL 是指结构化查询语言。使我们有能力访问数据库,SQL的功能有:面向数据库执行查询,取出数据库中数据,插入数据,查询数据,更新数据,删除数据,创建新数据库,创建新表等。
二、SQLite 使用
0、准备
如果你要使用SQLite数据库,必须导入系统的libsqlite3.0.tbd文件
1、创建数据库
在使用数据库之前你必须在本地有一个数据库,可以通过NSSearchPathForDirectoriesInDomains()函数来创建一个文件,为了方便查看数据库中的数据一般以.sqlite为文件后缀。
NSString *filePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject]stringByAppendingPathComponent:@"Student.sqlite"];
2、打开数据库
首先在自定义类中创建一个sqlite3类型的变量。然后调用sqlite3_open()函数就可以打开数据库了。
- (void)openDB {
// 如果数据库已经打开,没有必要再打开一次.
if (db) {
NSLog(@"数据库已经打开");
return;
}
// 创建数据库文件的路径
NSString *filePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject]stringByAppendingPathComponent:@"Student.sqlite"];
NSLog(@"%@",filePath);
// 参数1是C字符串,参数2是**,所传入的参数是地址
int result = sqlite3_open(filePath.UTF8String, &db);
// 根据函数返回值,判断执行是否正确
if (result == SQLITE_OK) {
NSLog(@"数据库打开成功!");
} else {
NSLog(@"数据库打开失败,错误码:%d", result);
}
}
3、创建表格
在对数据进行增删改查之前,你要有一个表格来存放数据,就如同书架对书进行分类、整理一样,数据在数据库中也不能随意放置,表格可以使数据更加的有序。
注意:对数据进行增删改查操作,一般会用到两个函数:sqlite3_exec()和sqlite3_prepare_v2()。
(1) sqlite3_exec()函数一般用于你对数据库进行操作,而数据库只向你回馈你的操作是否成功,不返回数据库中的数据信息时。表格的创建就是如此,因为我们只关心表格是否创建成功,而不需要知道表格中到底有什么。
(2) sqlite3_prepare_v2()函数用于你需要数据库对你反馈数据时,如查询数据,因为我们必须得到数据查询的结果,而不只是它是否成功的查询。
创建表格的sql语句:CREATE TABLE IF NOT EXISTS xxxTABLE (ID_S INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, sex TEXT, age INTEGER).
a. CREATE TABLE 是创建表格的关键词,
b. IF NOT EXISTS 是告诉系统当这个表格不存在是创建,这个词可以不写。
c. xxxTABLE 是你给创建的表起的名字。
d. 括号内是你表格内的每一个元素,用逗号链接。
- (void)createTable {
NSString *sql = @"CREATE TABLE IF NOT EXISTS dls160101 (ID_S INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, sex TEXT, age INTEGER)";
int result = sqlite3_exec(db, sql.UTF8String, nil, nil, nil);
if (result == SQLITE_OK) {
NSLog(@"插入表格成功!");
} else {
NSLog(@"插入表格失败,错误码:%d", result);
}
}
4、插入数据
有了表格后,就可以在表格中添加数据了,添加数据和创建表格除了sql语句不同外,其它都一样,我们只关心数据是否添加进去。
- (void)insertModel:(ModelOfStudent *)stu
{
// 插入数据的SQL语句
NSString *sql = [NSString stringWithFormat:@"INSERT INTO dls160101 (name, sex, age) VALUES ('%@', '%@', '%ld')", stu.name, stu.sex, stu.age];
int result = sqlite3_exec(db, sql.UTF8String, nil, nil, nil);
if (result == SQLITE_OK) {
NSLog(@"插入数据成功");
} else {
NSLog(@"插入数据失败,错误码:%d", result);
}
}
5、更新数据
更新数据是在原有数据基础上对数据改动,其结果是在原来的位置上修改了原来的数据,因此代码与之前没什么不同
- (void)updateModel:(ModelOfStudent *)stu id:(NSInteger)ID
{
// 更新数据 SQL语句
NSString *sql = [NSString stringWithFormat:@"UPDATE dls160101 SET name = '%@', sex = '%@', age = '%ld' WHERE ID_S = '%ld'", stu.name, stu.sex, stu.age, ID];
int reslut = sqlite3_exec(db, sql.UTF8String, nil, nil, nil);
if (reslut == SQLITE_OK) {
NSLog(@"更新数据成功");
} else {
NSLog(@"更新数据失败,错误码:%d", reslut);
}
}
6、删除数据
删除数据我们也只关心数据是否删除成功,与之前也没什么不同
- (void)deleteModelWithId:(NSInteger)ID
{
// 删除数据
NSString *sql = [NSString stringWithFormat:@"DELETE FROM dls160101 WHERE ID_S = '%ld'", ID];
int result = sqlite3_exec(db, sql.UTF8String, nil, nil, nil);
if (result == SQLITE_OK) {
NSLog(@"删除数据成功");
} else {
NSLog(@"删除数据失败,错误码:%d", result);
}
}
7、检索数据
/** 检索数据 API: sqlite3_stmt */
- (NSArray<ModelOfStudent *> *)selectWithSex:(NSString *)sex {
NSMutableArray *arr = [NSMutableArray array];
// 查找SQL语句
NSString *sql = [NSString stringWithFormat:@"SELECT * FROM dls160101 WHERE sex = '%@'", sex];
// 创建一个准备好的语句对象
sqlite3_stmt *stmt = nil;
// 为准备好的语句对象赋值(SQL语句内容)。
int result = sqlite3_prepare_v2(db, sql.UTF8String, -1, &stmt, nil);
if (result == SQLITE_OK) {
NSLog(@"查询中...");
// 当有下一行数据时,继续执行检索。
while (sqlite3_step(stmt) == SQLITE_ROW) {
// 查询条件匹配 使用函数簇将需要的列值取出来
const unsigned char *name = sqlite3_column_text(stmt, 1);
const unsigned char *sex = sqlite3_column_text(stmt, 2);
int age = sqlite3_column_int(stmt, 3);
// 创建model赋值
ModelOfStudent *stu = [[ModelOfStudent alloc]init];
stu.name = [NSString stringWithUTF8String:(const char *)name];
stu.sex = [NSString stringWithUTF8String:(const char *)sex];
stu.age = age;
// 添加到数组
[arr addObject:stu];
}
NSLog(@"查询结果,有%ld条记录匹配", arr.count);
sqlite3_step(stmt);
} else {
NSLog(@"未能启动查询过程,错误码:%d", result);
}
// 销毁stmt对象(内存管理)
sqlite3_finalize(stmt);
return arr;
}