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

一、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;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容