首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用sqlite3_bind_text()时iPhone应用程序崩溃

使用sqlite3_bind_text()时iPhone应用程序崩溃
EN

Stack Overflow用户
提问于 2010-06-18 04:15:53
回答 1查看 2.6K关注 0票数 1

我正在尝试制作一个简单的应用程序来存储和显示闪存卡,但是让我的SQLite运行起来却很麻烦。数据库连接是正常的,但是当我尝试插入时,它崩溃了,并且没有显示出哪里出了问题。这是我用来将闪存卡插入到表中的代码。

代码语言:javascript
复制
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()方法的弱链接。在本例中,NSStrings和def确实包含正确的值(这一点我很确定)。任何帮助都将不胜感激。我还没有完全掌握可移植的c语言。

EN

回答 1

Stack Overflow用户

发布于 2010-06-18 06:04:29

不是100%为什么它不工作,但我有几点建议:

去掉;在insert语句的末尾,我的语句中从来没有使用过。

将prepare和step放入if语句,如下所示

代码语言:javascript
复制
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模拟器并清理构建

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3065297

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档