0

次のコード:

-(NSArray *)getContentsWithContextTypes:(NSArray *)contextTypes
                            contextData:(NSArray *)contextData
{
    __block NSString *query = @"SELECT * FROM Texts_original1 WHERE ";
    [contextData enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
        NSString *attributeName = [self.contextTypeToDBQueryTexts          
                                        objectForKey:contextTypes[idx]];
        query = [query stringByAppendingFormat:@"%@ = \"%@\"", attributeName, obj];
        if(idx != contextData.count - 1)
        {
            query = [query stringByAppendingString:@" AND "];
        }
    }];

    [self.db open];
    FMResultSet *results = [self.db executeQuery:query];
    NSMutableArray *array = [NSMutableArray array];

    while([results next])
    {
        Content *content = [[TextualContent alloc] initWithResults:results];
        [array addObject:content];
    }

    [self.db close];
    return array;
}

実行すると、次のエラーが生成されます。

sqlite3_step の呼び出しエラー (21: メモリ不足) rs

ループの途中で発生します。33 の結果があるはずです。17 の後、そのエラーが発生し、ループが終了します。何か案は?ありがとう。

4

1 に答える 1

6

メモリの問題が発生するため、FMResultSet オブジェクトを閉じることを知っておくことが重要です。次のようにしてください。[resultSet close]

コード ロジックには触れませんが、データベース コードにいくつかの変更を加えます。

次のことを試してください。

-(NSArray *)getContentsWithContextTypes:(NSArray *)contextTypes
                        contextData:(NSArray *)contextData
{
 __block NSString *query = @"SELECT * FROM Texts_original1 WHERE ";
 [contextData enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) 
   {
     NSString *attributeName = [self.contextTypeToDBQueryTexts          
                                    objectForKey:contextTypes[idx]];
     query = [query stringByAppendingFormat:@"%@ = \"%@\"", attributeName, obj];
     if(idx != contextData.count - 1)
     {
        query = [query stringByAppendingString:@" AND "];
     }
  }];

self.db = [FMDatabase databaseWithPath:[self getDBPath]];    

if(![db open])
{
  NSLog(@"Could not open DB");
  return nil;
} 

FMResultSet *results = [self.db executeQuery:query];
NSMutableArray *array = [NSMutableArray array];

while([results next])
{
    Content *content = [[TextualContent alloc] initWithResults:results];
    [array addObject:content];
}

[results close]; //VERY IMPORTANT!
[self.db close];
return array;

}

于 2012-08-28T07:25:43.600 に答える