NSPredicate 条件查询或过虑
来源:互联网 发布:境外网络加速 编辑:程序博客网 时间:2024/05/22 00:18
NSPredicate用于查询和过滤
在SQL中作为查询条件通常用WHERE,但在COREDATA中作为查询条件就可以用到NSPredicate.
NSPredicate 不单可以和COREDATA中的FetchRequest 配合使用。也可以与NSArray配合使用。
NSPredicate 中支持的关键词和条件符:
1、>,<,>=,<=,= 比较运算符。
如:
NSPredicate * qcondition= [NSPredicate predicateWithFormat:@"salary >= 10000"];
2、字符串操作(包含):BEGINSWITH、ENDSWITH、CONTAINS
如:
@"employee.name BEGINSWITH[cd] '李'" //姓李的员工
@"employee.name ENDSWITH[c] '梦'" //以梦结束的员工
@"employee.name CONTAINS[d] '宗'" //包含有"宗"字的员工
注:[c]不区分大小写[d]不区分发音符号即没有重音符号[cd]既不区分大小写,也不区分发音符号。
3、范围:IN ,BWTEEN
如:
@"salary BWTEEN {5000,10000}"
@"em_dept IN '开发'"
4、自身:SELF,这个只针对字符数组起作用。
如:
NSArray * test = =[NSArray arrayWithObjects: @"guangzhou", @"beijing", @"shanghai", nil];
@"SELF='beijing'"
5、通配符:LIKE
LIKE 使用?表示一个字符,*表示多个字符,也可以与c、d 连用。
如:
@"car.name LIKE '?he?'" //四个字符中,中间为he
@"car.name LIKE '*jp'" //以jp结束
6、正则表达式:MATCHES
如:
NSString *regex = @"^E.+e$";//以E 开头,以e 结尾的字符。
NSPredicate *pre= [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex];
if([pre evaluateWithObject: @"Employee"]){
NSLog(@"matches YES");
}else{
NSLog(@"matches NO");
}
7、逻辑运算符:AND、OR、NOT
如:
@"employee.name = 'john' AND employee.age = 28"
8、占位符:
NSPredicate *preTemplate = [NSPredicate predicateWithFormat:@"name==$NAME"];
NSDictionary *dic=[NSDictionary dictionaryWithObjectsAndKeys:
@"Name1", @"NAME",nil];
NSPredicate *pre=[preTemplate predicateWithSubstitutionVariables: dic];
占位符就是字典对象里的key,因此你可以有多个占位符,只要key 不一样就可以了。
对数组过滤:
如:
NSMutableArray *carsCopy = [carsmutableCopy];
[carsCopyfilterUsingPredicate: predicate];//filterUsingPredicate和NSMutableArray构成新数组。
NSLog (@"%@", carsCopy);
predicate = [NSPredicatepredicateWithFormat:@"engine.horsepower > %d", 50];
results = [cars filteredArrayUsingPredicate: predicate];
NSLog (@"%@", results);
版权声明:本文为博主原创文章,未经博主允许不得转载。
- NSPredicate 条件查询或过虑
- NSPredicate 条件查询或过虑
- NSPredicate 条件查询或过虑
- NSPredicate 条件查询 过虑
- NSPredicate 条件查询 过虑
- NSPredicate 条件查询 过虑
- NSPredicate多条件查询
- core data 查询条件 NSPredicate使用
- CoreData条件查询之NSPredicate应用
- Hibernate Set查询过虑
- ios NSPredicate NSPredicate 查询、搜索
- NSPredicate 条件过滤
- Android SQLite 多条件查询或删除
- iOS 谓词查询NSPredicate
- IOS NSPredicate 查询、搜索
- IOS NSPredicate 查询、搜索
- IOS NSPredicate 查询、搜索
- iOS NSPredicate 查询、搜索
- oto餐饮app和服务器通信接口和规范定义(三)
- maven spring项目部署问题-source 1.3 中不支持注释 (请使用 -source 5 或更高版本以启用注释)
- 在windows 7搭建xcode开发环境
- open函数中参数选项O_EXCL解析
- Netty高性能大容量Socket并发(二):Netty简介
- NSPredicate 条件查询或过虑
- 按键精灵刷阿里妈妈广告联盟源码 V1.1版
- 杭电1062 Text Reverse
- 我的大学之路---《大学之路》读后感
- iOS QQ第三方登录
- 字体图标
- 客户端和服务端路径问题
- 查找练习 hash——出现过的数字
- .net 自动补零