iOS NSPredicate的学习讲解

  iOS Predicate 即谓词逻辑。和数据库的SQL语句具有相似性,都是从数据堆中根据条件进行筛选。

1.使用场景:        

       (1)NSPredicate给我留下最深印象的是两个数组求交集的一个需求,如果按照一般写法,需要2个遍历,但NSArray提供了一个filterUsingPredicate的方法,用了NSPredicate,就可以不用遍历!

       (2)在存储自定义对象的数组中,可以根据条件查询数组中满足条件的对象。

2.首先熟悉Predicate:

NSArray *array1 = [NSArray arrayWithObjects:@1,@2,@3,@5,@5,@6,@7, nil];

NSArray *array2 = [NSArray arrayWithObjects:@4,@5, nil];

// 表示筛选array1在array2中的元素!YES!其中SELF指向filteredArrayUsingPredicate的调用者。

/*测试方案:

NSPredicate *predicate1 = [NSPredicate predicateWithFormat:@"SELF  in %@",array2];

NSArray *temp1 = [array1 filteredArrayUsingPredicate:predicate1];

//表示array1在array2中元素

结果:

2015-11-08 10:55:19.879 NSPredicateDemo[11595:166012] obj ==5

2015-11-08 10:55:19.879 NSPredicateDemo[11595:166012] obj ==5

 

NSPredicate *predicate2 = [NSPredicate predicateWithFormat:@"SELF  in %@",array1];

NSArray *temp1 = [array2 filteredArrayUsingPredicate:predicate1];

结果:

2015-11-08 10:55:19.879 NSPredicateDemo[11595:166012] obj ==5

*/

NSPredicate *predicate1 = [NSPredicate predicateWithFormat:@"SELF  in %@",array2];

NSArray *temp1 = [array1 filteredArrayUsingPredicate:predicate1];

[temp1 enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {

NSLog(@"temp1 = %@",obj);

}];

/*

2015-11-08 10:55:19.879 NSPredicateDemo[11595:166012] obj ==5

2015-11-08 10:55:19.879 NSPredicateDemo[11595:166012] obj ==5

*/

 

3.基本语法

(1)比较运算符>,<,==,>=,<=,!=

可用于数值及字符串


 

(2)范围运算符:IN、BETWEEN

例:@"number BETWEEN {1,5}"

@"address IN {'shanghai','beijing'}"

 


 

(3)字符串本身:SELF

例:@“SELF == ‘APPLE’"

 


 

(4)字符串相关:BEGINSWITH、ENDSWITH、CONTAINS

例:@"name CONTAIN[cd] 'ang'"  //包含某个字符串

@"name BEGINSWITH[c] 'sh'"    //以某个字符串开头

@"name ENDSWITH[d] 'ang'"      //以某个字符串结束

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


 

(5)通配符:LIKE

例:@"name LIKE[cd] '*er*'"    //*代表通配符,Like也接受[cd].

@"name LIKE[cd] '???er*'"

 


 

 



文/九零猴VS久林(简书作者)
原文链接:http://www.jianshu.com/p/b2694972863e
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。
posted on 2016-09-10 14:37  envyhappy  阅读(1619)  评论(0编辑  收藏  举报