gpt4 book ai didi

iphone - 无法从 SQLite 数据库 iOS6.0 检索数据

转载 作者:搜寻专家 更新时间:2023-10-30 19:44:17 25 4
gpt4 key购买 nike

当我运行 build ios5.0 或更低版本时,Sqlite 响应正确并检索数据,它的工作正常但是当在 ios6.0 上运行时,我试图从 my.sqlite 数据库中获取数据,但它没有执行我的 if case。它总是进入其他条件。我做错了什么?我无法执行我的 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

最佳答案

将 this 放在 else 中,这样我们就可以看到产生的错误..

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));
}

关于iphone - 无法从 SQLite 数据库 iOS6.0 检索数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12650823/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com