Чтение той же записи из базы данных sqlite в приложении iphone - PullRequest
0 голосов
/ 18 марта 2012

В моем приложении для iphone я использую sqlite db.У меня есть значок, который начинает чтение из базы данных и сохраняет его в виде таблицы.Проблема заключается в следующем: если я снова выберу значок, он удваивает табличное представление с той же записью.Я знаю причину, потому что каждый раз, когда я выбираю значок, программа переходит к readSalesFromDatabase и tableView cellForRowAtIndexPath.Проблема в том, как этого избежать?
Вот мой код:

В AppDelegate:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:   (NSDictionary *)launchOptions
{
// db name
databaseName = @"saSh5.sqlite";    
//creating db
[self checkAndCreateDatabase];
//deals will hold the retrive data
deals = [[NSMutableArray alloc] init]; 
return YES;

}

-(void) readSalesFromDatabase {

if(sqlite3_open([databasePath UTF8String], &database) == SQLITE_OK) {
    // Setup the SQL Statement and compile it for faster access
    // const char *sqlStatement = "select * from UsersSale";
    const char *sqlStatement = "select us.userID , us.saleStoreID,  from UsersSale us  order by us.saleID";        


    sqlite3_stmt *compiledStatement;
    if(sqlite3_prepare_v2(database, sqlStatement, -1, &compiledStatement, NULL) == SQLITE_OK) {
        // Loop through the results and add them to the feeds array
         while(sqlite3_step(compiledStatement) == SQLITE_ROW) {
            // Read the data from the result row
            NSInteger auserID = sqlite3_column_int(compiledStatement, 0); 
            NSInteger asalStoreID = sqlite3_column_int(compiledStatement, 1); 

            // Create a new  Sale object with the data from the database                
            Deals *sfl  = [[Deals alloc] initWithName:auserID 
                                                            saleStoreID:asalStoreID]; 

            [deals addObject:sfl];
            [sfl release];

        }
}
    // Release the compiled statement from memory
    sqlite3_finalize(compiledStatement);

}
sqlite3_close(database);

}

В контроллере:

 - (void)viewDidLoad
{
  [super viewDidLoad];
  // Do any additional setup after loading the view from its nib.
  self.view.backgroundColor = [UIColor whiteColor];
  self.title = @"Deals";
  self.myTableView = [[UITableView alloc] initWithFrame:self.view.bounds  style:UITableViewStylePlain];
  self.myTableView.dataSource = self; 
  self.myTableView.delegate = self;
  [self.view addSubview:self.myTableView]; 

  AppDelegate *appDelegate = ( AppDelegate *)[[UIApplication sharedApplication] delegate];
  [appDelegate readSalesFromDatabase];  

}

- (UITableViewCell *) tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{

UILabel *product, *name; 
UITableViewCell *result = nil;
if ([tableView isEqual:self.myTableView]){
    static NSString *TableViewCellIdentifier = @"MyCells";
    result = [tableView dequeueReusableCellWithIdentifier:TableViewCellIdentifier];
    if (result == nil){
        result = [[UITableViewCell alloc]
                  initWithStyle: UITableViewCellStyleSubtitle reuseIdentifier:TableViewCellIdentifier];

    result = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault 
                                   reuseIdentifier:TableViewCellIdentifier] autorelease];
     AppDelegate *appDelegate = ( AppDelegate *)[[UIApplication sharedApplication] delegate];
    Deals *dls = (Deals *)[appDelegate.deals objectAtIndex:indexPath.row];        
    result.textLabel.lineBreakMode= UILineBreakModeWordWrap;

    product = [[[UILabel alloc] initWithFrame:CGRectMake(25.0, 0.0, 220.0, 15.0)] autorelease];
    product.tag = MAINLABEL_TAG;
    product.font = [UIFont systemFontOfSize:14.0];
    product.textAlignment = UITextAlignmentLeft;
    product.textColor = [UIColor blackColor];
    product.autoresizingMask = UIViewAutoresizingFlexibleLeftMargin | UIViewAutoresizingFlexibleHeight;
    product.text = dls.saleSpecificProduct;        

    [result.contentView addSubview:product];

}   

return result; 
}

1 Ответ

0 голосов
/ 18 марта 2012

Проблема в том, что всякий раз, когда вы выбираете значок, вызывается метод readSalesFromDatabase, который каждый раз добавляет данные в массив 'deals'.Так что избегайте избыточности одних и тех же данных, убедитесь, что удалили все объекты из массива сделок, прежде чем вызывать readSalesFromDatabase для продолжения, т.е.Надеюсь, это сработает.

...