无法从SQLite数据库iOS6.0检索数据
-
11-12-2019 - |
题
当我运行 build ios5.0 或更低版本时,Sqlite 响应正确并检索数据,其工作正常,但是当在 ios6.0 上运行时,我尝试从 my.sqlite 数据库获取数据,但它没有执行我的 if 情况。它总是以 else 状态进入。我做错了什么?我无法执行我的 if 情况,即 if(sqlite3_prepare_v2(database, sqlQuerry, -1, &querryStatement, NULL)==SQLITE_OK).
作为参考,请检查此代码。
NSLog(@"sqlite3_prepare_v2 = %d SQLITE_OK %d ",sqlite3_prepare_v2(sqlite, [strQuery UTF8String], -1, &compiledStatement, nil),SQLITE_OK);
if(sqlite3_prepare_v2(sqlite, [strQuery UTF8String], -1, &compiledStatement, nil)==SQLITE_OK)
{
NSLog(@"sqlite3_step = %d SQLITE_ROW %d ",sqlite3_step(compiledStatement),SQLITE_ROW);
while (sqlite3_step(compiledStatement)==SQLITE_ROW)
{ if(sqlite3_column_text(compiledStatement, 2) != nil)
modelObj.Name = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 2)];
}
}
else
{
}
关于iOS6.0日志打印
sqlite3_prepare_v2 = 1 SQLITE_OK 0
sqlite3_step = 21 SQLITE_ROW 100
关于iOS5.0日志打印
sqlite3_prepare_v2 = 0 SQLITE_OK 0
sqlite3_step = 100 SQLITE_ROW 100
解决方案
将其放入 else this 中,这样我们就可以看到所产生的错误。
if(sqlite3_prepare_v2(sqlite, [strQuery UTF8String], -1, &compiledStatement, nil)==SQLITE_OK)
{
NSLog(@"sqlite3_step = %d SQLITE_ROW %d ",sqlite3_step(compiledStatement),SQLITE_ROW);
while (sqlite3_step(compiledStatement)==SQLITE_ROW)
{ if(sqlite3_column_text(compiledStatement, 2) != nil)
modelObj.Name = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 2)];
}
}
else{
//error
NSLog(@"Failed to open database. Error: %s",sqlite3_errmsg(database));
}
其他提示
尝试从您的设备(或模拟器)中删除您的应用程序,然后清理并构建
我不是 100% 确定,但关于这一点:无效的 是一个 空白 *, 零 是一个 ID
所以如果你可以改变这个:
if(sqlite3_prepare_v2(sqlite, [strQuery UTF8String], -1, &compiledStatement, nil)==SQLITE_OK)
惠特这个:
if(sqlite3_prepare_v2(sqlite, [strQuery UTF8String], -1, &compiledStatement, NULL)==SQLITE_OK)
我只是把 nil 改成 NULL 。同样不是 100% 确定,但我在你的代码中看到的只有这一点。我总是使用 NULL :)
希望这有帮助...
不隶属于 StackOverflow