Xcode中的Sqlite更新语句无法正常工作

时间:2015-06-25 17:17:53

标签: ios xcode sqlite

我正在尝试在iOS应用中更新我的sqlite数据库中的表。我之前使用过这个更新语句,并且它有效。 以下语句返回sqlite提交值0,但是要更新的行中的所有字段都设置为"< null>"。 我没有收到错误消息......

声明有什么问题?

-(void) UpdateSMUser :(NSString *) tableName
       withField1:(NSString *) field1
      field1Value:(NSString *) field1Value
        andField2:(NSString *) field2
      field2Value:(NSString *) field2Value
        andField3:(NSString *) field3
      field3Value:(NSString *) field3Value
        andField4:(NSString *) field4
      field4Value:(NSString *) field4Value
{

[self openDB];

sqlite3_stmt *updateStmt;
NSString *sql = [NSString stringWithFormat:@"UPDATE SMUser SET UserID = ?, Profile = ?, SMReg = ?, Date = ? WHERE UserID = '%@'" ,field1Value];

if (sqlite3_prepare_v2(db, [sql UTF8String] , -1,
                       &updateStmt, NULL) == SQLITE_OK)
{

    sqlite3_bind_text(updateStmt, 1, [field1Value UTF8String], -1, SQLITE_TRANSIENT);
    sqlite3_bind_text(updateStmt, 2, [field2Value UTF8String], -1, SQLITE_TRANSIENT);
    sqlite3_bind_text(updateStmt, 3, [field3Value UTF8String], -1, SQLITE_TRANSIENT);
    sqlite3_bind_text(updateStmt, 4, [field4Value UTF8String], -1, SQLITE_TRANSIENT);
}

//  [self openDB];
char* errmsg;
NSLog(@"sqlite commit %d",sqlite3_exec(db, [sql UTF8String], NULL, NULL, &errmsg));
sqlite3_exec(db, [sql UTF8String], NULL, NULL, &errmsg);

if(SQLITE_DONE != sqlite3_step(updateStmt)){
    NSLog(@"Error while updating. %s", sqlite3_errmsg(db));
}
else{
    //   [self clearClick:nil];
}
sqlite3_finalize(updateStmt);
sqlite3_close(db);
}

非常感谢你...这让我发疯了!

1 个答案:

答案 0 :(得分:0)

sqlite3_exec()sqlite3_prepare*() / sqlite3_step() / sqlite3_finalize()周围的(过时的)包装器。 您不能将sqlite3_exec()与参数一起使用。

您的计划中仍然有正确的sqlite3_step()电话;只需删除sqlite3_exec()次来电。