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)比较运算符>,<,==,>=,<=,!=

可用于数值及字符串

1240

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

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

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

 

1240

(3)字符串本身:SELF

例:@“SELF == ‘APPLE’"

 

1240

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

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

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

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

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

1240

(5)通配符:LIKE

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

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

 

1240

具体代码见git:https://github.com/jiulin/NSPredicateDemo


 

文/九零猴VS久林(简书作者)
原文链接:http://www.jianshu.com/p/b2694972863e
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。

转载于:https://my.oschina.net/hejunbinlan/blog/786239

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值