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);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容