0

在设备中构建应用程序时出现性能问题。它实际上在我的数据库中。我有一张葡萄酒详细信息表,其中有 2114 个葡萄酒名称。为了获得所有这些葡萄酒的名称,我在以下代码中编写了这段代码appDelegate

-(NSMutableArray*)getWineDetails
{ 
   [wineDetailsList removeAllObjects];

   sqlite3_stmt* statement;
   const char *sql = "select *from wineDetails order by name";

   if (sqlite3_prepare_v2(database, sql, -1, &statement, NULL) != SQLITE_OK) 
   {
       NSAssert1(0, @"Error: failed to prepare statement with message '%s'.", sqlite3_errmsg(database));
   }

   while (sqlite3_step(statement) == SQLITE_ROW) 
   {
      primaryKey = sqlite3_column_int(statement, 0);
      //printf("\n primaryKey1 Value:%d",primaryKey);

      wineDetails *wineDets = [[wineDetails alloc] initWithPrimaryKey:primaryKey database:database];    
      [wineDetailsList addObject:wineDets];

      //printf("\n ==========================%d",[wineDetailsList count]);
      [wineDets release];
   }

   sqlite3_finalize(statement);
   printf("\n Inside AppDelegate .....wineDetailsList count:%d",[wineDetailsList count]);
   return wineDetailsList;

}

我在viewWillAppear另一个控制器中调用此方法,我必须在表视图中显示葡萄酒名称。

viewWillAppear代码:

-(void)viewWillAppear:(BOOL)animated
{
    CorkItAppDelegate* appDelegate = (CorkItAppDelegate*)[[UIApplication sharedApplication] delegate];
    winesList = [appDelegate getWineDetails];
    [tableView reloadData];
}

这里的问题是,当我在设备中构建它时,由于数据库中的日期量,导航到控制器需要太多时间。我应该怎么做才能摆脱这个性能问题?

谢谢,

莫尼什库马尔。

4

1 回答 1

0

作为一个快速建议,您可以在 name 列上添加一个索引,这可能会加快获取速度。此外,请确保您获取的内容不会超出您的需要。

于 2010-02-01T10:21:21.637 回答