(一一三)使用系统自带框架操作SQLite3数据库
2015-08-09 23:23
519 查看
系统自带的框架是基于C语言的,使用比较繁琐。
下面是使用步骤:
首先导入libsqlite3.0.dylib。
①在Document目录下打开数据库,如果没有则创建。
③查询数据。
查询数据通过执行step让STMT从前到后抓取数据,拿到数据后可以转换为OC字符串再处理。
下面是使用步骤:
首先导入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(@"准备失败"); }
相关文章推荐
- vs+mysql+ef配置方法
- 使用Elasticache创建多AZ的redis集群
- MySQL详解--锁
- memcache
- Hive集成Mysql作为元数据时,提示错误:Specified key was too long; max key length is 767 bytes
- mysql 经典sql收集
- 之前写的检测mysql 从服务器延迟的脚本
- 有用的MySQL语句
- ORACLE 第7节 创建和管理表
- (一)SQLite与SQL语句基础
- (一)SQLite与SQL语句基础
- Mysql优化20条建议
- mysql不能链接远程,报(Host '***.***.***.***' is not allowed to connect to this MySQL server)
- mysql常用语句
- Redis 入门指南
- SqlServer-函数
- java使用memcached1--安装与基本使用
- myeclipse中详细配置oracle数据库,mySql数据库(下)
- mongodb3.0.5的用户权限认证和使用可视化工具登录的一系列问题
- 谈谈SQL 语句的优化技术