NSPredicate用于查询和过滤
在SQL中作为查询条件通常用WHERE,但在COREDATA中作为查询条件就可以用到NSPredicate.
NSPredicate 不单可以和COREDATA中的FetchRequest 配合使用。也可以与NSArray配合使用。
NSPredicate 中支持的关键词和条件符:
1、>,<,>=,<=,= 比较运算符。
如:
2、字符串操作(包含):BEGINSWITH、ENDSWITH、CONTAINS
如:
注:[c]不区分大小写[d]不区分发音符号即没有重音符号[cd]既不区分大小写,也不区分发音符号。
3、范围:IN
如:
4、自身:SELF,这个只针对字符数组起作用。
如:
5、通配符:LIKE
如:
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
如:
8、占位符:
NSPredicate *preTemplate = [NSPredicate predicateWithFormat:@"name==$NAME"];
NSDictionary *dic=[NSDictionary dictionaryWithObjectsAnd
@"Name1", @"NAME",nil];
NSPredicate *pre=[preTemplate predicateWithSubstitutio
占位符就是字典对象里的key,因此你可以有多个占位符,只要key 不一样就可以了。
9. 分页查询
NSFetchRequest *request = [[NSFetchRequest alloc] init]; NSEntityDescription *entity = [NSEntityDescription entityForName:@"RSSEntryModel" inManagedObjectContext:_managedObjectContext]; [request setEntity:entity]; NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"articleDate" ascending:NO]; NSArray *sortDescriptors = [[NSArray alloc] initWithObjects:sortDescriptor, nil]; [request setSortDescriptors:sortDescriptors]; [request setFetchLimit:21]; [request setFetchOffset:_currentPage * 21]; NSArray *rssTemp = [_managedObjectContext executeFetchRequest:request error:&error];
转载自:http://blog.sina.com.cn/s/blog_6d58b63101015o6o.html http://blog.youkuaiyun.com/majiakun1/article/details/18139933