我在更新创建的 sqlite 表方面做了很多谷歌搜索,但我仍然无法在我的示例应用程序中更新我的表。谁能告诉我下面的代码有什么问题。IT 工作正常,直到sqlite3_prepare_v2 。一旦它到达如果(sqlite3_prepare_v2(database, sql, -1, &statement, NULL)==SQLITE_OK)条件它不会进入这个 if() 条件,谁能告诉这里发生了什么?
const char *dbpath = [[self DBPath] UTF8String];
if(sqlite3_open(dbpath, &database) == SQLITE_OK)
{
NSString *querySql=[NSString stringWithFormat:@"UPDATE Table1 SET AppEndTime = %@ WHERE AppID= %d",AppEndTime,appID];
const char *sql=[querySql UTF8String];
if(sqlite3_prepare_v2(database, sql, -1, &statement, NULL)==SQLITE_OK){
sqlite3_bind_int(statement, 1, sessionID);
sqlite3_bind_text(statement, 6, [sessionEndTime UTF8String], -1, SQLITE_TRANSIENT);
}
}
char* errmsg;
sqlite3_exec(database, "COMMIT", NULL, NULL, &errmsg);
if(SQLITE_DONE != sqlite3_step(statement)){
NSLog(@"Error while updating. %s", sqlite3_errmsg(database));
}
else{
sqlite3_reset(statement);
}
sqlite3_finalize(statement);
sqlite3_close(database);