sqlite各函数详解

1.sqlite3_open([database_path UTF8String], &db)

 database_path是要打开数据库文件的路径,是oc语言,要转化为c字符串。
&db存放数据库连接的句柄。

2.sqlite3_prepare_v2

NSString *sqlQuery = [NSString stringWithFormat:
                  @"SELECT * FROM %@",TABLENAME];
sqlite3_stmt * statement;
 if (sqlite3_prepare_v2(db, [sqlQuery UTF8String], -1, &statement, nil) == SQLITE_OK) {
   // db打开的数据库句柄;[sqlQuery UTF8String]要执行的sql语句;-1参数sql的字节数,为负则sql语句从开始到结束;&statement:sqlite3_step执行的变异好的准备语句的指针,有错位null;nil:指向sql语句中为执行的部分。
      while (sqlite3_step(statement) == SQLITE_ROW) {
      //sqlite3_step用于执行sqlite_prepare的准备语句。这个语句执行到结果的第一行。如果继续执行到第二行,需再次调用这个语句。[如没有返回值的语句insert、update、delete,只执行一次]
      //SQLITE_ROW查询时产生的结果,可以使用数据访问函数获得数据,执行sqlite3_step获取下一行数据。

      char *name = (char*)sqlite3_column_text(statement, 1);
        //sqlite3_column是前缀,用于获得sqlite3_step结果集中的列;第一个参数为sqlite_prepare返回的prepared statement对象的指针,第二个参数是返回的列的索引,最左列为0,行的列数用sqlite3_clumn_count()获得。

        NSString *nsNameStr = [[NSString alloc]initWithUTF8String:name];

        int age = sqlite3_column_int(statement, 2);

        char *address = (char*)sqlite3_column_text(statement, 3);
        NSString *nsAddressStr = [[NSString alloc]initWithUTF8String:address];

        NSLog(@"name:%@  age:%d  address:%@",nsNameStr,age, nsAddressStr);
    }
}else{
    NSLog(@"select error:%@",sqlQuery);

}

3.sqlite_finalize销毁被sqlite_prepare创建的准备语句。
4.sqlite3_exec(db, [sql UTF8String], NULL, NULL, &err)

 db描述的是数据库句柄;[sql UTF8String]要执行的SQL语句;第三个参数为回调函数;第四void *回调函数的第一个参数;err&错误信息,如果没有SQL问题则值为NULL

sqlite3_exec包裹了先前的sqlite3_prepare(),sqlite3_step,sqlite_finalize,可用简单的代码执行多条sql 语句。

你可能感兴趣的:(数据库,sqlite)