NSPredicate用于查询和过滤

 

在SQL中做为查询条件一般用WHERE,但在COREDATA中做为查询条件就能够用到NSPredicate.正则表达式

NSPredicate 不单能够和COREDATA中的FetchRequest 配合使用。也能够与NSArray配合使用。数组

 

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

一、>,<,>=,<=,= 比较运算符。orm

如:对象

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

二、字符串操做(包含):BEGINSWITH、ENDSWITH、CONTAINS开发

如:字符串

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

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

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

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

 

三、范围:IN   ,BWTEEN

如:

    @"salary BWTEEN {5000,10000}"

    @"em_dept IN '开发'"

 

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

如:

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

     @"SELF='beijing'"

 

五、通配符:LIKE

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

如:

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

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

 

六、正则表达式: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");

}

 

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

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

 

八、占位符:
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);

相关文章
相关标签/搜索