执行声明
使用诸如 sqlite3_prepare_v2()
之类的函数构造语句。
必须使用 sqlite3_finalize()
清除预准备的语句对象。如果出现错误,请不要忘记这一点。
如果使用参数 ,请使用 sqlite3_bind_xxx()
函数设置其值。
实际执行发生在调用 sqlite3_step()
时。
const char *sql = "INSERT INTO MyTable(ID, Name) VALUES (?, ?)";
sqlite3_stmt *stmt;
int err;
err = sqlite3_prepare_v2(db, sql, -1, &stmt, NULL);
if (err != SQLITE_OK) {
printf("prepare failed: %s\n", sqlite3_errmsg(db));
return /* failure */;
}
sqlite3_bind_int (stmt, 1, 42); /* ID */
sqlite3_bind_text(stmt, 2, "Bob", -1, SQLITE_TRANSIENT); /* name */
err = sqlite3_step(stmt);
if (err != SQLITE_DONE) {
printf("execution failed: %s\n", sqlite3_errmsg(db));
sqlite3_finalize(stmt);
return /* failure */;
}
sqlite3_finalize(stmt);
return /* success */;