【问题标题】:Not inserting rows in sqlite database in iOS不在 iOS 的 sqlite 数据库中插入行
【发布时间】:2013-08-07 11:31:06
【问题描述】:

我有一个方法打算从自定义对象插入到我的 sqlite 数据库中:

- (void)insertCustomEntity:(CustomEntity *)customEntity
{
   NSString *filePath = [FileMngr copyDatabaseToDocuments];

   sqlite3 *database;

   if (sqlite3_open([filePath UTF8String], &database) == SQLITE_OK) {
       const char *sqlStatement = "INSERT OR REPLACE INTO Entities (id, type, timestamp, result) VALUES (?, ?, ?, ?)";
    sqlite3_stmt *compiledStatement;

        NSLog(@"Could not prepare statement: %s\n", sqlite3_errmsg(database));

       if (sqlite3_prepare_v2(database, sqlStatement, -1, &compiledStatement, NULL) == SQLITE_OK) {
           sqlite3_bind_int(compiledStatement, 1, customEntity.id);
           sqlite3_bind_int(compiledStatement, 2, customEntity.type);
           sqlite3_bind_int64(compiledStatement, 3, customEntity.timestamp);
           sqlite3_bind_int(compiledStatement, 4, customEntity.result);
       }

          if(sqlite3_step(compiledStatement) == SQLITE_DONE) {

          }
          else {
             NSLog(@"Step: %d\n", sqlite3_step(compiledStatement));
          }
       }

       sqlite3_finalize(compiledStatement);
   }

   sqlite3_close(database);
} 

我已经进行了一段时间的测试并且正在插入数据,但突然它停止了,我现在在我的第二个NSLog 处获得了一个 5 步代码。为什么会发生这种情况,如果它以前工作过?我尝试了在一些帖子中找到的几个选项,例如将sqlite3_step(compiledStatement) 放在sqlite3_prepare_v2 中,但我一直无法插入。我做错了什么?

提前致谢

【问题讨论】:

  • 在放置 NSLog(@"%s",sqlite3_errmsg(database)); 后是否收到任何类型的错误消息并将相同的语句放在else部分并检查错误消息

标签: ios database sqlite insert


【解决方案1】:

我不确定,但您的某些牙套似乎不匹配?无论如何,错误代码 5 表示您的数据库已锁定。

http://www.sqlite.org/c3ref/c_abort.html

检查是否有其他东西正在访问您的数据库(或者在某些情况下您的数据库没有关闭,在这种情况下您的代码需要更改)。尝试以下解决方案来解决它:-

sqlite3 database is getting locked

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-09-09
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多