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 语句。