博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
(一一三)使用系统自带框架操作SQLite3数据库
阅读量:4704 次
发布时间:2019-06-10

本文共 1434 字,大约阅读时间需要 4 分钟。

系统自带的框架是基于C语言的,使用比较繁琐。

下面是使用步骤:

首先导入libsqlite3.0.dylib。

①在Document目录下打开数据库,如果没有则创建。

NSString *sqlitePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"test.sqlite"];// 数据库不存在会自动创建sqlite3 *db = NULL;int state = sqlite3_open(sqlitePath.UTF8String, &db);if (state == SQLITE_OK) {    NSLog(@"打开数据库成功");}else{    NSLog(@"打开数据库失败");}
②创建一张表和插入数据。

const char *sql = "CREATE TABLE IF NOT EXISTS t_product (id integer PRIMARY KEY AUTOINCREMENT, name text NOT NULL, price real);";char *err = NULL;sqlite3_exec(db, sql, NULL, NULL, &err);sql = "INSERT INTO t_product (name,price) values ('饮料',10)";sqlite3_exec(db, sql, NULL, NULL, &err);

③查询数据。

查询数据通过执行step让STMT从前到后抓取数据,拿到数据后可以转换为OC字符串再处理。

// 查询数据// STMT会自动向后指数据sqlite3_stmt *stmt = NULL; // STMT用来取出查询的结果sql = "SELECT * FROM t_product";state = sqlite3_prepare(db, sql, -1, &stmt, NULL);if (state == SQLITE_OK) {    NSLog(@"准备成功");    while(sqlite3_step(stmt) == SQLITE_ROW){ // 成功取出一条数据        const char *cname = (const char*)sqlite3_column_text(stmt, 1);// 第0列是id,取出第1列数据name        const char *cprice = (const char*)sqlite3_column_text(stmt, 2);// 取出第2列数据price        NSString *name = [NSString stringWithUTF8String:cname];        NSString *price = [NSString stringWithUTF8String:cprice];        NSLog(@"%@ %@",name,price);    }    }else{    NSLog(@"准备失败");}

转载于:https://www.cnblogs.com/aiwz/p/6154068.html

你可能感兴趣的文章
Linux下安装Tomcat
查看>>
windows live writer 2012 0x80070643
查看>>
tomcat 和MySQL的安装
查看>>
git常用操作
查看>>
京东SSO单点登陆实现分析
查看>>
u-boot启动第一阶段
查看>>
MySQL批量SQL插入性能优化
查看>>
定义列属性:null,default,PK,auto_increment
查看>>
用户画像展示
查看>>
C#中StreamReader读取中文出现乱码
查看>>
使用BufferedReader的时候出现的问题
查看>>
批处理文件中的路径问题
查看>>
hibernate出现No row with the given identifier exists问题
查看>>
为什么wait()和notify()属于Object类
查看>>
配置NRPE的通讯
查看>>
匹配两个空格之间的字符。。。
查看>>
CSS 文字溢出 变成省略号 ...
查看>>
Spring事务
查看>>
java编程基础(三)流程控制语句
查看>>
让数据库跑的更快的7个MySQL优化建议
查看>>