iPhone应用程序崩溃与sqlite3_bind_text()

时间:2010-06-17 20:15:53

标签: iphone objective-c sqlite

我正在尝试创建一个存储和显示闪存卡的简单应用程序,但是我很难让我的SQLite工作。数据库连接很好,但是当我尝试插入时,它崩溃并且没有指出出错的地方。这是我用来将闪存卡插入表格的代码。

const char *insert = "INSERT OR REPLACE INTO LIST (TERM, DEFINITION) VALUES (?, ?);";
sqlite3_stmt *statement;
sqlite3_prepare_v2(database, insert, -1, &statement, nil);
sqlite3_bind_text(statement, 1, [term UTF8String], -1, SQLITE_TRANSIENT);
sqlite3_bind_text(statement, 2, [def UTF8String], -1, SQLITE_TRANSIENT);
sqlite3_step(statement);
sqlite3_finalize(statement);

我已经确定绑定文本方法是我之前放置的一些NSLog()方法的弱链接。在这个例子中,term和def是NSStrings,它们保持正确的值(我非常清楚)。任何帮助,将不胜感激。我还没有掌握便携式c。

1 个答案:

答案 0 :(得分:2)

不是100%为什么它不起作用,但我有一些建议:

摆脱;在插入声明的最后,我从来没有在我的插入声明中。

将准备和步骤放入if语句中

if(sqlite3_prepare_v2(db, sql, -1, &statement, NULL) != SQLITE_OK) {
        NSAssert1(0, @"Error while creating add statement. '%s'", sqlite3_errmsg(db));
}
if (SQLITE_DONE != sqlite3_step(statement)) {
        NSAssert1(0, @"Error while inserting data. '%s'", sqlite3_errmsg(db));
}

这些都不会有所帮助,但它可能会让你更接近错误。

另外,有一件事可能会有所帮助。当我使用SQLite时,如果我对数据库进行更改或者我没有输入正确的数据,那将是一件非常痛苦的事情。我花了很多时间重置iPhone模拟器并清理构建