首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用sqlite3语句从tableview中删除

使用sqlite3语句从tableview中删除
EN

Stack Overflow用户
提问于 2012-08-25 07:10:41
回答 2查看 1.6K关注 0票数 1

我正在尝试删除由SQL数据库填充的UITableView中的一行。

我使用的sql语句来自一个名为databaseHanderClass的类。该方法接受一个整数,它是删除数据库中一行的id --主键。

代码语言:javascript
复制
-(BOOL) deleteFromDatabase: (NSInteger)delete_id
{
   FMDatabase *dbHandler = [FMDatabase databaseWithPath: [Utility getDatabasePath]];
   BOOL success;
   @try 
   {
        [dbHandler open];        
        success = [dbHandler executeUpdate:@"DELETE FROM inputs WHERE id=%d", delete_id];
        [dbHandler close];
   }
   @catch (NSException *exception) 
   {
       NSLog(@"fejl...%@", exception);
   }
   @finally 
   {
       return success;
   }
}

我在UITableView中用于删除的方法如下所示。

代码语言:javascript
复制
- (void)tableView:(UITableView *)tableView commitEditingStyle (UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath 
{
    if (editingStyle == UITableViewCellEditingStyleDelete) 
    {
        [tableView deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationFade];            

    }   
    else if (editingStyle == UITableViewCellEditingStyleInsert) 
    {
         //statement
    }   
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-08-27 20:35:35

您需要实现以下方法:这应该是有效的

对于您的数据库代码,请尝试:

代码语言:javascript
复制
-(BOOL) deleteFromDatabase: (NSInteger)delete_id
{
    FMDatabase *dbHandler = [FMDatabase databaseWithPath: [Utility getDatabasePath]];
    BOOL success = NO;

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

    [dbHandler beginTransaction];
    success = [dbHandler executeUpdate:@"DELETE FROM inputs WHERE id = ?", 
    [NSNumber numberWithInt:delete_id]];

    [dbHandler commit]; 
    [dbHandler close];
    return success;
}

对于"commitEditingStyle“方法,可以尝试执行以下操作:

代码语言:javascript
复制
- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath 
{
      if (editingStyle == UITableViewCellEditingStyleDelete) {
      NSInteger row_number_to_be_deleted = indexPath.row;
      //call method to delete from database
      [DatabaseHandler deleteFromDatabase:row_number_to_be_deleted];

      //now, fetch all details from Database
      self.dataSource = [DatabaseHandler getAllData];
      [tableView reloadData];
}

对于"NumberOfRowsInSection":

代码语言:javascript
复制
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return [self.dataSource count];
}

对于"canEditRowAtIndexPath":

代码语言:javascript
复制
-(BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath *)indexPath
{
    return YES;
}

对于"editingStyleForRowAtIndexPath":

代码语言:javascript
复制
- (UITableViewCellEditingStyle)tableView:(UITableView *)tableView
       editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath
{
    NSLog(@"Editing Style-DELETE %i", [indexPath row]);
    return UITableViewCellEditingStyleDelete;
}

对于"commitEditingStyle":

代码语言:javascript
复制
 - (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath 
 {

     if (editingStyle == UITableViewCellEditingStyleDelete) 
     {
         // Do whatever data deletion you need to do...
         // Delete the row from the data source
         /* This HAS to be changed by YOU */ 
         Employee* emp = [self.dataSource objectAtIndex:[indexPath row]]; 
         NSLog(@"Delete row %i", [indexPath row]);
         [DataEngine removeData:emp];
         [self.dataSource removeObjectAtIndex:[indexPath row]];
     } 
     [self.tableView reloadData];
}
票数 0
EN

Stack Overflow用户

发布于 2012-08-25 07:19:16

commitEditingStyle中,您需要一次性删除数据和行。否则,您的表可能处于不一致状态。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12117763

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档