本文首发地址
本文有洲洲哥整理提供,转载请说明出处!!!
关于谓词,在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 比较运算符
- 查询数据源中ages
大于等于
23的: >=
NSPredicate * predicate = [NSPredicate predicateWithFormat:@" ages >= 23"];
- 查询数据ages
小于等于
23的:<=
NSPredicate * predicate = [NSPredicate predicateWithFormat:@" ages <= 23"];
- 查询数据ages
不等于
23的:!=、<>
NSPredicate * predicate = [NSPredicate predicateWithFormat:@" ages <> 23"];
3.2 逻辑运算符
- 多条件查询
NSPredicate * predicate = [NSPredicate predicateWithFormat:@" ages = 23 AND name = 'w2' "];
- OR、||:逻辑或,要求其中一个表达式为YES时,结果就是YES
- 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开发信息 请以关注洲洲哥 的微信公众号,不定期有干货推送:
这里写图片描述
网友评论