加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

(一一三)使用系统自带框架操作SQLite3数据库

发布时间:2020-12-12 19:41:08 所属栏目:百科 来源:网络整理
导读:系统自带的框架是基于C语言的,使用比较繁琐。 下面是使用步骤: 首先导入libsqlite3.0.dylib。 ①在Document目录下打开数据库,如果没有则创建。 NSString *sqlitePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES)

系统自带的框架是基于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,&err);
sql = "INSERT INTO t_product (name,price) values ('饮料',10)";
sqlite3_exec(db,&err);

③查询数据。

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

// 查询数据
// STMT会自动向后指数据
sqlite3_stmt *stmt = NULL; // STMT用来取出查询的结果
sql = "SELECT * FROM t_product";
state = sqlite3_prepare(db,-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(@"准备失败");
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读