• coredata总结三 NSPredicate 条件查询或过虑


    NSPredicate用于查询和过滤

    在SQL中作为查询条件通常用WHERE,但在COREDATA中作为查询条件就可以用到NSPredicate.

    NSPredicate 不单可以和COREDATA中的FetchRequest 配合使用。也可以与NSArray配合使用。

     

    NSPredicate 中支持的关键词和条件符:

    1、>,<,>=,<=,= 比较运算符。

    如:

         NSPredicate * qcondition= [NSPredicate predicateWithFormat:@"salary >= 10000"];

    2、字符串操作(包含):BEGINSWITH、ENDSWITH、CONTAINS

    如:

            @"employee.name BEGINSWITH[cd] '李'" //姓李的员工

         @"employee.name ENDSWITH[c] '梦'"   //以梦结束的员工

         @"employee.name CONTAINS[d] '宗'"   //包含有"宗"字的员工

    注:[c]不区分大小写[d]不区分发音符号即没有重音符号[cd]既不区分大小写,也不区分发音符号。

    3、范围:IN   ,BWTEEN

    如:

        @"salary BWTEEN {5000,10000}"

        @"em_dept IN '开发'"

    4、自身:SELF,这个只针对字符数组起作用。

    如:

         NSArray * test = =[NSArray arrayWithObjects: @"guangzhou", @"beijing", @"shanghai", nil];

         @"SELF='beijing'"

     

    5、通配符:LIKE

         LIKE 使用?表示一个字符,*表示多个字符,也可以与c、d 连用。

    如:

         @"car.name LIKE '?he?'" //四个字符中,中间为he

         @"car.name LIKE '*jp'"   //以jp结束

    6、正则表达式:MATCHES

    如:

    NSString *regex = @"^E.+e$";//以E 开头,以e 结尾的字符。
    NSPredicate *pre= [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];
    if([pre evaluateWithObject: @"Employee"]){
    NSLog(@"matches YES");

    }else{
    NSLog(@"matches NO");

    }

     

    7、逻辑运算符:AND、OR、NOT
    如:

          @"employee.name = 'john' AND employee.age = 28"

    8、占位符:
    NSPredicate *preTemplate = [NSPredicate predicateWithFormat:@"name==$NAME"];
    NSDictionary *dic=[NSDictionary dictionaryWithObjectsAndKeys:
    @"Name1", @"NAME",nil];
    NSPredicate *pre=[preTemplate predicateWithSubstitutionVariables: dic];
    占位符就是字典对象里的key,因此你可以有多个占位符,只要key 不一样就可以了。

     

    对数组过滤:

    如:

     NSMutableArray *carsCopy = [carsmutableCopy];

        [carsCopyfilterUsingPredicate: predicate];//filterUsingPredicate和NSMutableArray构成新数组。

        NSLog (@"%@", carsCopy);

        

        predicate = [NSPredicatepredicateWithFormat:@"engine.horsepower > %d", 50];

        results = [cars filteredArrayUsingPredicate: predicate];

        NSLog (@"%@", results);

  • 相关阅读:
    java第19次
    Unity3D常用的生命周期函数
    Unity3D结合ZXing生成中间带图标的二维码并保存
    Unity查看当前内存使用情况(针对移动端开发)
    Unity 获取鼠标悬停位置下的UI或3D物体对象
    【Unity3D】获取鼠标在三维空间(世界坐标系)的位置
    【Unity3D—C#】按下任意按键,返回按键的名称 以及 KeyCode键码详解
    Unity UGUI获取鼠标在屏幕的准确点击位置
    ML-Agent:通过TF#使用训练完成的模型数据
    对《ml-agent:Win10下环境安装》更新
  • 原文地址:https://www.cnblogs.com/wangzhendong/p/4007214.html
Copyright © 2020-2023  润新知