我需要在iPhone应用程序中插入一堆数据,但是在不同的表中。表名在此数据中。
这就是我想要做的事情:
NSString *statement = @"insert into ? values (?, ?, 0)";
sqlite3_stmt *compiledStatement;
if(sqlite3_prepare_v2(database, [statement UTF8String], -1, &compiledStatement, NULL) == SQLITE_OK)
{
for(UpdateItems *item in updateData){
sqlite3_bind_text( compiledStatement, 1, [item.table UTF8String], -1, SQLITE_TRANSIENT);
sqlite3_bind_text( compiledStatement, 2, [item.code UTF8String], -1, SQLITE_TRANSIENT);
sqlite3_bind_text( compiledStatement, 3, [item.data UTF8String], -1, SQLITE_TRANSIENT);
while(YES){
NSInteger result = sqlite3_step(compiledStatement);
if(result == SQLITE_DONE){
break;
}
else if(result != SQLITE_BUSY){
break;
}
}
sqlite3_reset(compiledStatement);
}
} else
printf("db error: %s\n", sqlite3_errmsg(database));
sqlite3_finalize(compiledStatement);
sqlite3_close(database);
运行上面的脚本时,我收到错误:没有这样的表:?这是正常的,因为在sqlite3_prepare_v2语句中数据还没有绑定,所以SQLite不知道该表。 / p>
现在我将在循环中移动sqlite3_prepare_v2块并使用stringWithFormat我将使用表名更改第一个问号并在准备之后,但是还有其他任何解决方案 - 更简单吗?
答案 0 :(得分:1)
这是最简单的正确解决方案。
但是,每次不准备查询都会带来性能优势。如果性能是一个问题,那么我建议创建一个从表名到准备好的查询的映射。然后,您只需在第一次遇到表名时准备查询。