2

我正在运行以下选择查询,它在 iOS 8.2 之前可以 100% 运行。此查询在 iOS 8.1 及更早版本中返回了完美的结果集。该应用程序卡在 sqlite3_step 上,需要永远完成。有人知道为什么吗?我的应用程序卡在用户设备上。下面是查询和代码。

NSString *sqlStatement = @"Select W.woorde, R.woorde, W.woordIDs, R.woordIDs from masterWoorde W, masterWoorde R, masterWaardes WD, masterWoorde Rr where Rr.woorde LIKE ? And Rr.woordIDs=WD.skoonLeidraadID and WD.leidraadID=W.woordIDs and WD.resultaatID=R.woordIDs ORDER BY W.woorde COLLATE NOCASE, R.woorde COLLATE NOCASE";

if (prepareStatus == SQLITE_OK) {
            sqlite3_bind_text(select_statement, 1, [dboObject.frases UTF8String], -1, SQLITE_STATIC);

            while (sqlite3_step(select_statement) == SQLITE_ROW) {

                productSModel * aProduct = [[productSModel alloc] init];
                aProduct.frases = [NSString stringWithUTF8String:(char *)sqlite3_column_text(select_statement, 0)];
                aProduct.ABC = [NSString stringWithUTF8String:(char *)sqlite3_column_text(select_statement, 1)];
                aProduct.CDE = sqlite3_column_int(select_statement, 2);
                aProduct.FGH = sqlite3_column_int(select_statement, 3);

                [arrResult addObject:aProduct];
            }
        }
4

1 回答 1

1

这个问题可以追溯到 iOS 8.1 和 iOS 8.2 之间 SQLite 的变化。请参阅iOS 8.2 下的 Sqlite3 查询变得非常慢

于 2015-04-10T22:36:20.407 回答