当前位置 : 主页 > 手机开发 > ios >

ios – sqlite 3“SQL错误’内存不足'(7)”objc

来源:互联网 收集:自由互联 发布时间:2021-06-11
嗨,任何人都可以指出我做错了吗?错误是这样的: SQL error 'out of memory' (7) - (NSArray *)RecipeInfo{ NSMutableArray *retval = [[NSMutableArray alloc] init]; NSString *query = [NSString stringWithFormat:@"SELECT key, na
嗨,任何人都可以指出我做错了吗?错误是这样的:

SQL error 'out of memory' (7)



  - (NSArray *)RecipeInfo
{    
    NSMutableArray *retval = [[NSMutableArray alloc] init];
    NSString *query = [NSString stringWithFormat:@"SELECT key, name FROM recipes WHERE type = \'%@\'", self.RecipeType];

NSLog(query);

sqlite3_stmt *statement;

if (sqlite3_prepare_v2(_database, [query UTF8String], -1, &statement, NULL) != SQLITE_OK)
{
    NSLog(@"[SQLITE] Error when preparing query!");
    NSLog(@"%s SQL error '%s' (%1d)", __FUNCTION__, sqlite3_errmsg(_database), sqlite3_errcode(_database));

    }
    else
    {
        while (sqlite3_step(statement) == SQLITE_ROW)
        {
            int uniqueId = sqlite3_column_int(statement, 0);
            char *nameChars = (char *) sqlite3_column_text(statement, 1);
            NSString *name = [[NSString alloc] initWithUTF8String:nameChars];
            RecipeInfo *info = [[RecipeInfo alloc] initWithUniqueId:uniqueId name:name];
            [retval addObject:info];
        }

        sqlite3_finalize(statement);
    }
return retval;
}

sql在我使用的数据库管理环境中执行正常,它必须与我使用sql api的方式有关,有人能发现什么错误吗?

如果您忽略打开数据库并且指针为NULL(或者,如rmaddy所说,如果由于任何原因它为NULL),您可以容易地得到该错误.在您打开数据库的位置放置一个日志语句,并确保它成功并且您有一个有效的sqlite3指针.
网友评论