zoukankan      html  css  js  c++  java
  • 一个数据表对象(NSManagedObject)加入排序

    eg:数据库表对象


    @interface Meditation : NSManagedObject

    @property (nonatomic, retain) NSString * order;//用来排序的属性值。用0、1、2、3...排序

    @end


    //在这种方法里操作

    - (void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)sourceIndexPath toIndexPath:(NSIndexPath *)destinationIndexPath

    {

        Meditation *sourceMeditation=[self.dataSource objectAtIndex:sourceIndexPath.row];

        sourceMeditation.order =[NSString stringWithFormat:@"%i",destinationIndexPath.row];

        [sourceMeditation.managedObjectContext save:nil];

    //两种情况一种是上移,第二种是下移

    1.sourceIndexPath.row>destinationIndexPath.row

    2.sourceIndexPath.row>destinationIndexPath.row


        if (sourceIndexPath.row < destinationIndexPath.row)

        {

            for (NSInteger i = sourceIndexPath.row+1; i <= destinationIndexPath.row; i ++)

            {

                Meditation *m = [self.dataSource objectAtIndex:i];

                m.order =[NSString stringWithFormat:@"%i",[m.attribute6 integerValue]-1];

                [sourceMeditation.managedObjectContext save:nil];

            }

            

        }else

        {

            for (NSInteger i = sourceIndexPath.row-1; i >= destinationIndexPath.row; i--)

            {

                Meditation *m = [self.dataSource objectAtIndex:i];

                m.order =[NSString stringWithFormat:@"%i",[m.attribute6 integerValue]+1];

                [sourceMeditation.managedObjectContext save:nil];

            }

        }


    }

    //当对象被删除的时候(依照order的升序排列)。把删除数据以下的数据对象的order属性值-1

    -(void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath{

        if (editingStyle == UITableViewCellEditingStyleDelete) {

            for (int i=indexPath.row; i<self.dataSource.count; i++) {

                Meditation *m = [self.dataSource objectAtIndex:i];

                m.order =[NSString stringWithFormat:@"%i",[m.attribute6 integerValue]-1];

                [appDelegate saveContext];

            }


    }

    版权声明:本文博客原创文章,博客,未经同意,不得转载。

  • 相关阅读:
    实际运用中DataSet、DataTable、DataRow点滴
    SQL语句AND 和 OR执行的优先级
    CS程序,服务器端弹出MessageBox.Show()之类的UI操作???禁止
    使用动态SQL语句实现简单的行列转置(动态产生列)
    表的行列转置
    统计每种车型的数量
    由CAST()函数在.NET1.1和.NET4.0下处理机制不同所引发的BUG
    转载——网站重构的8点建议
    float,double和decimal类型
    优化DB2缓冲页的大小
  • 原文地址:https://www.cnblogs.com/bhlsheji/p/4750922.html
Copyright © 2011-2022 走看看