美文网首页iOS在路上
NSPredicate 条件查询过滤(等同于sql后面where

NSPredicate 条件查询过滤(等同于sql后面where

作者: 然亦伞 | 来源:发表于2016-11-18 14:46 被阅读164次

    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 不一样就可以了。

    对数组查询:

    如:

    //从数组筛选联系人列表

    NSString*search =self.searchbar.text;

    NSPredicate*pred = [NSPredicatepredicateWithFormat:[NSStringstringWithFormat:@"cname Like[cd] '*%@*' OR ctel1Like[cd] '*%@*' OR ctel2Like[cd] '*%@*'",search,search,search]];

    NSArray*arr = [self.peopleArrfilteredArrayUsingPredicate:pred];

    相关文章

      网友评论

        本文标题:NSPredicate 条件查询过滤(等同于sql后面where

        本文链接:https://www.haomeiwen.com/subject/snzjpttx.html