iOS实用知识点

iOS SQLite 数据库使用及常用SQL语句

2016-08-15  本文已影响2470人  shen888

<h1>一、SQLite 简介</h1>
SQL 是指结构化查询语言。使我们有能力访问数据库,SQL的功能有:面向数据库执行查询,取出数据库中数据,插入数据,查询数据,更新数据,删除数据,创建新数据库,创建新表等。
<h1>二、SQLite 使用</h1>
<h2>0、准备</h2>
如果你要使用SQLite数据库,必须导入系统的libsqlite3.0.tbd文件
<h2>1、创建数据库</h2>
在使用数据库之前你必须在本地有一个数据库,可以通过NSSearchPathForDirectoriesInDomains()函数来创建一个文件,为了方便查看数据库中的数据一般以.sqlite为文件后缀。

NSString *filePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject]stringByAppendingPathComponent:@"Student.sqlite"];

<h2>2、打开数据库</h2>
首先在自定义类中创建一个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);
    }
}

<h2>3、创建表格 </h2>
在对数据进行增删改查之前,你要有一个表格来存放数据,就如同书架对书进行分类、整理一样,数据在数据库中也不能随意放置,表格可以使数据更加的有序。
<b>注意:对数据进行增删改查操作,一般会用到两个函数:sqlite3_exec()和sqlite3_prepare_v2()。</b>
(1) sqlite3_exec()函数一般用于你对数据库进行操作,而数据库只向你回馈你的操作是否成功,不返回数据库中的数据信息时。表格的创建就是如此,因为我们只关心表格是否创建成功,而不需要知道表格中到底有什么。
(2) sqlite3_prepare_v2()函数用于你需要数据库对你反馈数据时,如查询数据,因为我们必须得到数据查询的结果,而不只是它是否成功的查询。
<b>创建表格的sql语句:</b>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);
    }
}

<h2>4、插入数据 </h2>
有了表格后,就可以在表格中添加数据了,添加数据和创建表格除了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);
    }
}

<h2>5、更新数据 </h2>
更新数据是在原有数据基础上对数据改动,其结果是在原来的位置上修改了原来的数据,因此代码与之前没什么不同

- (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);
    }
}

<h2>6、删除数据 </h2>
删除数据我们也只关心数据是否删除成功,与之前也没什么不同

- (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);
    }
}

<h2>7、检索数据 </h2>

/** 检索数据 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;
}
上一篇下一篇

猜你喜欢

热点阅读