CoreData - 查询

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、自身:SELF,这个只针对字符数组起作用。

如:

NSArray * test = =[NSArray arrayWithObjects: @"guangzhou", @"beijing", @"shanghai", nil];
@"SELF='beijing'"

4、通配符:LIKE

LIKE 使用?表示一个字符,*表示多个字符,也可以与c、d 连用。
如:

@"car.name LIKE '?he?'" //四个字符中,中间为he
@"car.name LIKE[c] '*jp'"   //以jp结束

5、正则表达式: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");
}

6、范围:IN ,BWTEEN

如:

@"salary BWTEEN {5000,10000}"
@"em_dept IN '开发'"

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];

9. 查找的String包含了正则特用的字符

输入的字符包含: ?.{}[+*() 等特殊字符时,异常报错
SQLCore dispatchRequest: exception handling request: <NSSQLFetchRequestContext: 0x600000796ae0> , Can’t do regex matching, reason: (Can’t open pattern U_REGEX_RULE_SYNTAX (string name, pattern {.}, case 1, canon 0)) with userInfo of (null), 需要多输入的字符转换:

// NSString *inputName = @"?.{}[\+*() ";
NSString *convertedName = [NSRegularExpression escapedPatternForString: inputName];
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值