0

我正在使用 FMDB 与 SQLite 数据库进行交互。我让它插入行很好,但是当我尝试更新其中一个时,更新不会发生,但没有报告错误。

这就是我正在做的事情:

userHistoryDB.logsErrors = YES;
userHistoryDB.traceExecution = YES;
NSString *query = [NSString stringWithFormat:
         @"INSERT OR IGNORE INTO phrase_history (code, %@) VALUES (\"%@\", 0); "
         @"UPDATE OR FAIL phrase_history SET %@ = %@ + 1 WHERE code = \"%@\";",
         countTypeColumn,
         phraseCode,
         countTypeColumn,
         countTypeColumn,
         phraseCode];
BOOL rc = [userHistoryDB executeUpdate:query];

rc 是 YES,表示没有任何问题。这是一个示例调用:

<FMDatabase: 0x5303af0> executeUpdate: INSERT OR IGNORE INTO phrase_history (code, presented) VALUES ("grapefruit", 0); UPDATE OR FAIL phrase_history SET presented = presented + 1 WHERE code = "grapefruit";

就 FMDB 而言,这执行得很好。但是,记录不会增加。SQL 没有任何问题——如果我将它粘贴到 sqlite3 命令行工具中,它会完美运行。

关于它为什么不运行的任何想法?我尝试无济于事的事情:

  • 在事务中包含行
  • 使用 executeQuery 运行
  • 仅运行更新(已手动插入条目)。
  • 用头撞桌子。
4

2 回答 2

3

您有两个 sqlite 语句,FMDB 不会自动将您的单个复合行转换为两个单独的语句。您需要单独运行它们,这就是 sqlite3 命令行工具正在做的事情。

于 2010-11-22T16:14:40.173 回答
0

您的数据库存储在哪里?在捆绑?还是在其他位置?

如果您的项目文件夹中有数据库,当您编译时,Xcode 将在 build/Debug 或 build/Release 中创建应用程序包,这是您的数据库所在的位置,而不是项目文件夹中的那个。检查 build/Debug(Release) 中的数据库是否更新?您的项目文件夹中的数据库将不会更新,因为您可能会请求应用程序包的位置。

当您通过命令行检查数据库时,您是在项目包中还是在 build/Debug(Release) 文件夹中检查数据库?

于 2010-11-30T05:58:25.997 回答