第一遍 复杂方法 : 数据库查询一个表中userID 然后进行分类 中间去重 获得ID个数  放到section 中  显示

#pragma mark -  查询不同的ID 各数 

- (void)checkIDsWithCount{

    

    RLMRealm * realm = [[RealmConfigurationshared]realm];

//    RLMResults * selectIDResults = [[CarVideoInfoObj objectsInRealm:realm where:@"userID !=0"] sortedResultsUsingKeyPath:@"hostID" ascending:NO];

    RLMResults * selectIDResults = [[CarVideoInfoObj  allObjectsInRealm:realm] sortedResultsUsingKeyPath:@"hostID"ascending:NO];

    NSLog(@"selectIDResults  is  %@",selectIDResults);

    

    NSMutableArray *userID = [NSMutableArrayarray];

    allSectionDic = [NSMutableDictionarynew];

    for(CarVideoInfoObj  * obj in selectIDResults){

        NSInteger userId = obj.userID;

        NSNumber * key = @(userId);

        NSMutableArray  * objects = [allSectionDicobjectForKey:key];

        if(objects == nil){

                objects = [NSMutableArraynew];

                [allSectionDicsetObject:objects forKey:key];

        }

        [objects  addObject:obj];

//        NSLog(@"objectID==== %ld",(long)userId);

//        [userID addObject:@(userId)];

    }

    NSLog(@"all carVideoInfo object list is %@",allSectionDic);

    // 去重查询个数

    NSLog(@"%lu",(unsignedlong)allSectionDic.count);

     //统计数组相同元素的个数

    sectionDic = [[NSMutableDictionaryalloc] init];

    set = [NSSetsetWithArray:userID];

    for (NSString *setString  inset){

        //需要去掉的元素数组

        NSMutableArray *filteredArray = [[NSMutableArrayalloc]initWithObjects:setString, nil];

        NSMutableArray *dataArray = userID;

        NSPredicate * filterPredicate = [NSPredicatepredicateWithFormat:@"NOT (SELF IN %@)",filteredArray];

        //过滤数组

        NSArray * reslutFilteredArray = [dataArray filteredArrayUsingPredicate:filterPredicate];

        NSLog(@"Reslut Filtered Array = %@",reslutFilteredArray);

        int number = (int)(dataArray.count-reslutFilteredArray.count);

        NSLog(@"number :%d",number);

        [sectionDicsetObject:[NSStringstringWithFormat:@"%d",number] forKey:setString];

    }

    NSLog(@"dic  is%@", sectionDic);

        _userIDdic = [[NSDictionaryalloc]init];

        _userIDdic = sectionDic;

    

        NSArray * keys = [_userIDdicallKeys] ;

       dicArray =[NSArrayarray];

        dicArray = keys;

}

 

#pragma mark - UICollectionView delegate dataSource

#pragma mark 定义展示的Section的个数

-(NSInteger)numberOfSectionsInCollectionView:(UICollectionView *)collectionView

{

    // section  个数

       returnset.count;

}

#pragma mark 定义展示的UICollectionViewCell的个数

-(NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section

{

//    sectionDic  is{

//        10006 = 14;

//        10003 = 23;

//    }

    NSString *key = [dicArrayobjectAtIndex:section];

    NSString * count = [_userIDdicobjectForKey:key];

    return count.integerValue;

    

//        return 2;

    //    NSLog(@"2222_videoMode%@",self.videoMode);

    //    NSLog(@"_videoMode.videos count  is   %lu",(unsigned long)[self.videoMode.carVideoInfoObjArray count]);

    //    return [self.videoMode.carVideoInfoObjArray count];

    

}

 第二种方法  查询表格  讲userID 设置为字典的key 不进获取到了以userID不同的个数作为 section 而且每个 userI获取了每个userID的数据  为赋值显示 打好了基础 (仍不完善)

#pragma mark -  查询不同的ID 各数 

- (void)checkIDsWithCount{

    

    RLMRealm * realm = [[RealmConfigurationshared]realm];

    RLMResults * selectIDResults = [[CarVideoInfoObj  allObjectsInRealm:realm] sortedResultsUsingKeyPath:@"hostID"ascending:NO];

    NSLog(@"selectIDResults  is  %@",selectIDResults);

    allSectionDic = [NSMutableDictionarynew];

    for(CarVideoInfoObj  * obj in selectIDResults){

        NSInteger userId = obj.userID;

        NSNumber * key = @(userId);

        NSMutableArray  * objects = [allSectionDicobjectForKey:key];

        if(objects == nil){

                objects = [NSMutableArraynew];

                [allSectionDicsetObject:objects forKey:key];

        }

        [objects  addObject:obj];

    }

    NSLog(@"all carVideoInfo object list is %@",allSectionDic);

    _userIDdic = [[NSDictionaryalloc]init];

    _userIDdic = allSectionDic;

    NSArray * keys = [_userIDdicallKeys] ;

    dicArray =[NSArrayarray];

    dicArray = keys;

}

#pragma mark - UICollectionView delegate dataSource

#pragma mark 定义展示的Section的个数

-(NSInteger)numberOfSectionsInCollectionView:(UICollectionView *)collectionView

{

    // section  个数

       returnallSectionDic.count;

}

#pragma mark 定义展示的UICollectionViewCell的个数

-(NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section

{

    NSString *key = [dicArrayobjectAtIndex:section];

//    NSString * count = [_userIDdic objectForKey:key];

    

    return [[_userIDdicobjectForKey:key] count];

}

 

第三种: 完善后的方法 及赋值

UICollectionView 数据库元素分组 多种section分开显示的更多相关文章

  1. highCharts图表应用-实现多种图表的显示

    在数据统计和分析业务中,有时需要在一个图表中将柱状图.饼状图.曲线图的都体现出来,即可以从柱状图中看出具体数据.又能从曲线图中看出变化趋势,还能从饼状图中看出各部分数据比重.highCharts可以轻 ...

  2. win8.1 win10存储设备和驱动器分开显示

    win10同理如下: Windows 8.1不仅将资源管理器重命名为文件管理器,还将用户熟悉的“计算机/我的电脑”改名为“这台电脑”,同时还将原先的布局进行了重构,于是用户最终看到的是这样一个界面: ...

  3. css隐藏页面元素的多种方法

    在平常的样式排版中,我们经常遇到将某个模块隐藏,下面我整理了一下隐藏元素的多种方法以及对比(有的占据空间,有的不占据空间.有的可以点击,有的不能点击.): ( 一 )  display:  none; ...

  4. IE6 IE7 IE8(Q) 负边距 (margin) 导致元素溢出 hasLayout 容器时显示异常

    标准参考 根据W3C CSS2.1规范第8.3节中的描述,边距属性设置了一个框的边距区的宽度.'margin' 缩写属性设置所有四边的边距,而其它的边距属性( 'margin-top' ,'margi ...

  5. 对App数据库元素进行简单的设计

    假如对<豆瓣>进行简单的数据库元素设计; 分析页面: 简单的豆瓣一共有以下页面{ 活动页面 活动详情页面 电影页面 电影详情页面 影院页面(一般不用到数据库,不及于数据库考虑) 我的{ 活 ...

  6. RB1001: IE6 IE7 IE8(Q) 负边距 (margin) 导致元素溢出 hasLayout 容器时显示异常

    标准参考 根据W3C CSS2.1规范第8.3节中的描述,边距属性设置了一个框的边距区的宽度.'margin' 缩写属性设置所有四边的边距,而其它的边距属性( 'margin-top' ,'margi ...

  7. Atitit 数据库排除某一列 字段 显示

    Atitit  数据库排除某一列 字段  显示 GROUP_CONCAT  行列转换 mysql利用group_concat()合并多行数据到一行_Mysql_脚本之家 sELECT GROUP_CO ...

  8. 【css】绝对定位的元素在 ie6 下不显示

    问题描述: 在 ie6 中如果一个浮动元素与绝对定位元素相邻的话,在某些情况下绝对定位元素将会消失. 产生原因: 只有当绝对定位元素的邻近浮动元素的宽度大于父层宽度减 3 时(即如果父层宽度是 300 ...

  9. ios8 UITableView section不显示

    ios8 如果UITableView只设置viewForHeaderInSection,则可能section不能显示,iOS7及以下版本显示正常. 解决方案: 设置heightForHeaderInS ...

随机推荐

  1. mysql数据库无法连接(JDBC)java.net.ConnectException: Connection timed out

    数据库无法连接(JDBC) 用户名密码正确,但是一直报错:Connection timed out 后来知道了原因:我用的是BAE提供的云mysql数据库,对访问的IP有限制 ,所以在本机上无法连接. ...

  2. Basic Authentication in ASP.NET Web API

    Basic authentication is defined in RFC 2617, HTTP Authentication: Basic and Digest Access Authentica ...

  3. 解题报告:poj 3070 - 矩阵快速幂简单应用

    2017-09-13 19:22:01 writer:pprp 题意很简单,就是通过矩阵快速幂进行运算,得到斐波那契数列靠后的位数 . 这是原理,实现部分就是矩阵的快速幂,也就是二分来做 矩阵快速幂可 ...

  4. jenkins+gradle打包android遇到的坑

    1.gradle与gradlew的选择 配置project,我们选择gradle进行打包.会看到如下图配置项.然而很多网上教程中给出的选择是第一项.只能这么说,如果你是新建一个androidDemo, ...

  5. java开发设计六大基本原则

    1.遵循单一职责原则 定义:不要存在多于一个导致类变更的原因.通俗的说,即一个类只负责一项职责.一个类只专注于做一件事: 高内聚,低耦合: 实例: 普通的手表如果有一个指针坏了,那么手表将不再转动,而 ...

  6. Android DB那些事-数据库加密

    说到数据库加密,目前最好且唯一的方案就是SqlCipher对sqlite3整体加密,微信也用的它.开源,且支持很多平台. 单就Android来说,集成不算太麻烦,1个jar包,3个so库,1个zip. ...

  7. [Vue]组件——实现动态组件:keep-alive的使用

    1.在app.vue中用一个 <keep-alive> 元素将其动态组件包裹起来: keepAlive为true时,第一次被创建的时候缓存下来,为false时,不会缓存 <keep- ...

  8. js的数组问题

    目录: 1. 遇到的问题 2. 解决方案 3. 内部原理 4. 总结 1. 遇到的问题 前天在写js时,遇到了一个很奇怪的问题:我有两个数组变量a.b,在经过一些运算后,数组b中有一些值,然后我就把数 ...

  9. 《Think in Java》(十三)字符串

    学完这章后,对 Java 字符串有了重新的认识.自己也看了下 CharSequence,String,StringBuilder,StringBuffer 等类的实现代码.

  10. ItemsSource数据源 或 集合属性 的定义 ——> 的数据源定义(典型)

    在Xaml中: ItemsSource="{Binding Path=GridDataSource.PoliceforceDataSource}" 在ViewModel中: Obs ...