0

我正在使用以下代码从客户表中读取记录。由于某种原因,返回的结果集始终为空。

    -(NSMutableArray *) getCustomers
{
    NSMutableArray *customers = [[NSMutableArray alloc] init];

    NSString *databaseName = @"Customers.db";

    NSArray *documentsPath = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); 
    NSString *documentsDir = [documentsPath objectAtIndex:0];

    NSString *databasePath = [documentsDir stringByAppendingPathComponent:databaseName];

    FMDatabase *db = [FMDatabase databaseWithPath:databasePath];

    if(![db open]) 
    {
        return nil; 
    }

    FMResultSet *results = [db executeQuery:@"SELECT * FROM customers"];

    while([results next]) 
    {
        Customer *customer = [[Customer alloc] init];


        customer.firstName = [results stringForColumn:@"firstname"];
        customer.lastName = [results stringForColumn:@"lastname"];

        [customers addObject:customer];

    }

    [db close];

    return customers; 


}

我已多次检查数据库并显示数据,但由于某种原因 FMDB 无法检索它!

4

1 回答 1

2

将 db log errors 设置为 true,这将显示登录控制台,您可以在其中找到问题。

FMDatabase *db = [FMDatabase databaseWithPath:databasePath];
db.logsErrors = YES;
于 2011-10-24T18:53:27.470 回答