iOS[谓词]NSPredicate的使用

274 阅读4分钟

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

关于谓词,在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);
}

有些地方说的不到位,还请各位看官指正。。。

  • 欢迎各位一块学习,提高逼格!
  • 也可以添加洲洲哥的微信公众号

可以来微信公众号(洲洲哥)后台给我们留言。 快来扫码关注我们吧!

qrcode.jpg