iOS Predicate 即谓词逻辑。和数据库的SQL语句具备类似性,都是从数据堆中根据条件进行筛选。 git
1.使用场景: github
(1)NSPredicate给我留下最深印象的是两个数组求交集的一个需求,若是按照通常写法,须要2个遍历,但NSArray提供了一个filterUsingPredicate的方法,用了NSPredicate,就能够不用遍历! 数据库
(2)在存储自定义对象的数组中,能够根据条件查询数组中知足条件的对象。 数组
2.首先熟悉Predicate: 测试
NSArray *array1 = [NSArray arrayWithObjects:@1 ,@2,@3 ,@5 ,@5 ,@6,@7, nil]; .net
NSArray *array2 = [NSArray arrayWithObjects:@4,@5, nil]; code
// 表示筛选array1在array2中的元素!YES!其中SELF指向filteredArrayUsingPredicate的调用者。 orm
/*测试方案: 对象
NSPredicate *predicate1 = [NSPredicate predicateWithFormat:@"SELF in %@",array2]; ci
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*'"