0

我的表中有 2 列(wordid、word)。我尝试检索单词来测试 sqlite 部分。并且下面的语句总是返回 NULL。我很确定我的数据库没有问题,因为我已经在 Firefox 附加组件(sqlite 管理器)中测试了该语句。

NSString *str;    

const char *dbpath = [_databasePath UTF8String];
sqlite3_stmt *statement;

if (sqlite3_open(dbpath, &_db) == SQLITE_OK){


    NSString *querySQL = [NSString stringWithFormat:@"SELECT word FROM Circle_En WHERE wordid=2"];

    const char *query_stmt = [querySQL UTF8String];

    if (sqlite3_prepare_v2(_db,query_stmt, -1, &statement, NULL) == SQLITE_OK){
        if (sqlite3_step(statement) == SQLITE_ROW){
            str = [[NSString alloc]initWithUTF8String:(char *) sqlite3_column_text(statement, 0)];
        }
    }

    sqlite3_finalize(statement);
    sqlite3_close(_db);
}

任何建议表示赞赏。

最好的问候,
塔哈

4

1 回答 1

0

您在列号部分犯了错误。

因为这个词在 index(columnnumber) 1. 所以你需要有这个:

str = [[NSString alloc]initWithUTF8String:(char *) sqlite3_column_text(statement, 1)];
于 2013-09-08T03:14:32.843 回答