美文网首页专注iOS开发(OC/Swift)
iOS[谓词]NSPredicate的使用

iOS[谓词]NSPredicate的使用

作者: 洲洲哥 | 来源:发表于2017-03-15 15:16 被阅读232次

本文首发地址
本文有洲洲哥整理提供,转载请说明出处!!!

关于谓词,在iOS上是苹果官方提供,在android上官方是不提供的,但是有一些第三方是已经实现的。

1.先看看和他类似的SQL语句吧

写过T-SQL的朋友应该都熟悉,不管你是用的SQL SERVER....
例如SQL

select * from person where name = ‘洲洲哥’

这句话的意思就是查询person表中,name为洲洲哥的所有信息。
这里这个person就是我们数据库中的表名。

那如果我们在iOS中要这样查询该怎么写呢?别急,,,看洲洲哥为你解疑答惑。

2: iOS中使用谓词查询数组内容

#### 使用场景

要查询`Arry`中根据其中的一个或多个属性去确定适合条件的`arry`
有些同学可能要说,可以用循环啊!!你说的没错!循环之后,再去找符合   的对象,中间要有一个`if`判断是必不可少的!!

如果你要使用谓词就不一样了。简单好用
实例化一个谓词-----其实就是实例化一个查询条件

NSPredicate * predicate = [NSPredicate predicateWithFormat:@" name = 23"];

关键代码如下

// Person类代码如下
@interface Person : NSObject
@property(nonatomic,strong) NSString * name;
@property(nonatomic,assign) NSInteger  ages;
-(instancetype)initWith:(NSString *)names withAge:(NSInteger)ages ;
@end


// new3个Person对象装进数组
Person * p1 = [[Person alloc] initWith:@"w1" withAge:12 ];
Person * p2 = [[Person alloc] initWith:@"w2" withAge:23 ];
Person * p3 = [[Person alloc] initWith:@"w3" withAge:50 ];

NSArray * arry = @[p1,p2,p3];

// 查询name 为`w1`的对象
NSPredicate * predicate = [NSPredicate predicateWithFormat:@" name = 23"];

// 得到符合条件的数据集合
NSArray * pers = [arry filteredArrayUsingPredicate:predicate];
for (Person * pss in pers) {
     NSLog(@"-----%@",pss.name);
}

怎么样?是不是很简单!要比你去循环好的多了多吧?

3:更多灵活比较运算符

3.1 比较运算符

  1. 查询数据源中ages大于等于23的: >=
NSPredicate * predicate = [NSPredicate predicateWithFormat:@" ages >= 23"];
  1. 查询数据ages小于等于23的:<=
NSPredicate * predicate = [NSPredicate predicateWithFormat:@" ages <= 23"];
  1. 查询数据ages不等于23的:!=、<>
NSPredicate * predicate = [NSPredicate predicateWithFormat:@" ages <> 23"];

3.2 逻辑运算符

  1. 多条件查询
NSPredicate * predicate = [NSPredicate predicateWithFormat:@" ages = 23 AND name = 'w2' "];
  1. OR、||:逻辑或,要求其中一个表达式为YES时,结果就是YES
  2. NOT、 !:逻辑非,对原有的表达式取反

3.3 字符串比较运算符
BEGINSWITH:检查某个字符串是否以指定的字符串开头(如判断字符串是否以a开头:BEGINSWITH 'a')
ENDSWITH:检查某个字符串是否以指定的字符串结尾
CONTAINS:检查某个字符串是否包含指定的字符串
LIKE:检查某个字符串是否匹配指定的字符串模板。其之后可以跟?代表一个字符和代表任意多个字符两个通配符。比如"name LIKE 'ac'",这表示name的值中包含ac则返回YES;"name LIKE '?ac'",表示name的第2、3个字符为ac时返回YES。
MATCHES:检查某个字符串是否匹配指定的正则表达式。虽然正则表达式的执行效率是最低的,但其功能是最强大的,也是我们最常用的。

注:字符串比较都是区分大小写和重音符号的。如:café和cafe是不一样的,Cafe和cafe也是不一样的。如果希望字符串比较运算不区分大小写和重音符号,请在这些运算符后使用[c],[d]选项。其中[c]是不区分大小写,[d]是不区分重音符号,其写在字符串比较运算符之后,比如:name LIKE[cd] 'cafe',那么不论name是cafe、Cafe还是café上面的表达式都会返回YES。

3.4.集合运算符

ANY、SOME:集合中任意一个元素满足条件,就返回YES。
ALL:集合中所有元素都满足条件,才返回YES。
NONE:集合中没有任何元素满足条件就返回YES。如:NONE person.age < 18,表示person集合中所有元素的age>=18时,才返回YES。
IN:等价于SQL语句中的IN运算符,只有当左边表达式或值出现在右边的集合中才会返回YES。
array[index]:返回array数组中index索引处的元素

array[FIRST]:返回array数组中第一个元素
array[LAST]:返回array数组中最后一个元素
array[SIZE]:返回array数组中元素的个数

3.5.直接量

在谓词表达式中可以使用如下直接量

FALSE、NO:代表逻辑假
TRUE、YES:代表逻辑真
NULL、NIL:代表空值
SELF:代表正在被判断的对象自身
"string"或'string':代表字符串
数组:和c中的写法相同,如:{'one', 'two', 'three'}。
数值:包括证书、小数和科学计数法表示的形式
十六进制数:0x开头的数字
八进制:0o开头的数字
二进制:0b开头的数字
3.6.保留字

下列单词都是保留字(不论大小写)
AND、OR、IN、NOT、ALL、ANY、SOME、NONE、LIKE、CASEINSENSITIVE、CI、MATCHES、CONTAINS、BEGINSWITH、ENDSWITH、BETWEEN、NULL、NIL、SELF、TRUE、YES、FALSE、NO、FIRST、LAST、SIZE、ANYKEY、SUBQUERY、CAST、TRUEPREDICATE、FALSEPREDICATE
注:虽然大小写都可以,但是更推荐使用大写来表示这些保留字

案例

NOT IN 用法

NSArray *filterArray = @[@"w1", @"w2"];
NSArray *array = @[p1,p2,p3];
NSPredicate *predicates = [NSPredicate predicateWithFormat:@"NOT (name IN %@)", filterArray];
NSArray * perArry = [array filteredArrayUsingPredicate:predicates];
for (Person * ps in perArry) {
    NSLog(@"------>%@",ps.name);
}

如有问题可添加我的QQ:1290925041
还可添加QQ群:234812704(洲洲哥之说)
欢迎各位一块学习,提高逼格!
也可以添加洲洲哥的微信公众号

更多消息

更多信iOS开发信息 请以关注洲洲哥 的微信公众号,不定期有干货推送:

这里写图片描述

相关文章

网友评论

    本文标题:iOS[谓词]NSPredicate的使用

    本文链接:https://www.haomeiwen.com/subject/znmlnttx.html