0
私は新しく、まだ疑問が残っています。 データベーステーブルから配列にデータをロードするクラスを作成しました。次に、TableViewでDeleteを選択してデータベースからレコードの削除を実装したいと思います。私は困っている。TableViewでアイテムIDを特定し、データベースを削除する方法
データベースのinTableViewから項目の説明を表示する際に問題があります。フィールド_idは表示されますが、フィールド名は表示されません。
あたかもオブジェクトが配列内に存在しないかのようです。
私が持っている他の問題は、データベースを削除する方法です。
//Variáveis para coleta de dados do banco
NSString *ID_KEY = @"_id";
NSString *NAME_KEY = @"name";
NSString *DESCRIPTION_KEY = @"description";
#pragma mark - Métodos Usuários
- (NSArray *)GetCategories
{
//Cria uma instância do DataBase para poder trabalhar
FMDatabase *db = [Database DBWrite];
//Cria um array para receber os dados do select
NSMutableArray *array = [[[NSMutableArray alloc] init] autorelease];
//Testamos se o DataBase está aberto
if ([db open]){
//Precisamos de um ResultSet para receber e trabalhar com o resultado do SELECT
FMResultSet *rs = [db executeQuery:@"SELECT _id, name, description FROM category"];
//Fazemos um LOOP para carregar o array com os dados do SELECT
while ([rs next]) {
//Campo _id
int _idI = [rs intForColumn:@"_id"];
NSNumber *fieldID = [[NSNumber alloc] initWithInt:_idI];
//Campo name
NSString *fieldName = [rs stringForColumn:@"name"];
//Campo description
NSString *fieldDescription = [rs stringForColumn:@"description"];
//Dicionário para guardar as chaves e objetos
NSMutableDictionary *rowDict = [[NSMutableDictionary alloc] initWithCapacity:3];
//Guardamos as informações do ID e Name no Log para futura consulta em caso de erros
//NSLog(@"%@ - %@ - %@", fieldID, fieldName, fieldDescription);
//Adiciona os valores e chaves de cada linha
[rowDict setObject:fieldID forKey: ID_KEY];
[rowDict setObject:fieldName forKey: NAME_KEY];
[rowDict setObject:fieldDescription forKey: DESCRIPTION_KEY];
NSLog(@"%@ - %@ - %@", [rowDict objectForKey:ID_KEY], [rowDict objectForKey:NAME_KEY], [rowDict objectForKey:DESCRIPTION_KEY]);
[array addObject:rowDict];
[fieldID release];
[fieldName release];
[fieldDescription release];
[rowDict release];
}
[rs close];
[db close];
}
return array;
}
-(void)viewWillAppear:(BOOL)animated
{
[super viewWillAppear:animated];
//Cria e inicializa a classe categoria
Category *categoria = [[Category alloc] init];
//Verifica se o array está vazio e inicializado e cria
if (arrCategory != nil)
[arrCategory release];
//Carrega os dados da categoria
arrCategory = [[NSMutableArray alloc] initWithArray:[categoria GetCategories]];
//Inicializa tudo
[categoria release];
[tbvCategory reloadData];
}
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
//Cria a célula
UITableViewCell *celula = [tableView dequeueReusableCellWithIdentifier:@"celula"];
if (celula == nil) {
celula = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"celula"] autorelease];
//Define o estilo da célula
[celula setSelectionStyle:UITableViewCellSelectionStyleGray];
}
NSDictionary *rowVals = (NSDictionary *) [arrCategory objectAtIndex:indexPath.row];
//Pega o valor do campo Name
NSString *fieldName = (NSString *) [rowVals objectForKey:@"name"];
NSLog(@"%@ - %@", [rowVals objectForKey:@"name"], fieldName);
//Here is ERROR
celula.textLabel.text = [NSString stringWithFormat:@"%@", [rowVals objectForKey:@"name"]];
return celula;
}
- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath
{
Category *categoria = [[Category alloc] init];
NSDictionary *dici = (NSDictionary *) [arrCategory objectAtIndex:indexPath.row];
NSNumber *linha = (NSNumber *) [dici objectForKey:@"_id"];
NSNumber *selRow = [[NSNumber alloc] initWithInteger: indexPath.row];
[categoria DeleteCategory:selRow];
[tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];
[arrCategory removeObjectAtIndex:indexPath.row];
[tableView endUpdates];
[tableView reloadData];
}
はNSLogsは* GetCategories *メソッド内から正しく印刷されますか?メソッド名にはキャメルケースを使用し、クラス名は大文字で始めるのが良い方法です。 – lawicko