谓词(NSPredicate)

来源:互联网 发布:红蜘蛛软件卸载不了 编辑:程序博客网 时间:2024/04/30 19:27

谓词(NSPredicate)

1. 什么是谓词

  • The NSPredicate class is used to define logical conditions used to constrain a search either for a fetch or for in-memory filtering.
  • NSPredicate类是用来定义逻辑条件约束的获取或内存中的过滤搜索。

2. 常用运算符

2.1 比较运算符

  • =、==:判断两个表达式是否相等,在谓词中=和==是相同的意思都是判断,而没有赋值这一说
  • >=,=>:判断左边表达式的值是否大于或等于右边表达式的值
  • <=,=<:判断右边表达式的值是否小于或等于右边表达式的值
  • >:判断左边表达式的值是否大于右边表达式的值
  • <:判断左边表达式的值是否小于右边表达式的值
  • !=、<>:判断两个表达式是否不相等
  • BETWEEN:BETWEEN表达式必须满足表达式 BETWEEN {下限,上限}的格式,要求该表达式必须大于或等于下限,并小于或等于上限

2.2 逻辑运算符

  • AND、&&:逻辑与,要求两个表达式的值都为YES时,结果才为YES。
  • OR、||:逻辑或,要求其中一个表达式为YES时,结果就是YES
  • NOT、 !:逻辑非,对原有的表达式取反

2.3 字符串比较运算符

  • BEGINSWITH:检查某个字符串是否以指定的字符串开头(如判断字符串是否以a开头:BEGINSWITH ‘a’)
  • ENDSWITH:检查某个字符串是否以指定的字符串结尾
  • CONTAINS:检查某个字符串是否包含指定的字符串
  • LIKE:检查某个字符串是否匹配指定的字符串模板。
    • 其之后跟?代表一个字符
    • 其之后跟*代表任意多个字符
    • 比如”name LIKE ‘cy‘”,这表示name的值中包含cy则返回YES;”name LIKE ‘?cy*’”,表示name的第2、3个字符为cy时返回YES。
  • MATCHES:检查某个字符串是否匹配指定的正则表达式。

注: 字符串比较都是区分大小写和重音符号的。如:café和cafe是不一样的,Cafe和cafe也是不一样的。如果希望字符串比较运算不区分大小写和重音符号,请在这些运算符后使用[c],[d]选项。其中[c]是不区分大小写,[d]是不区分重音符号,其写在字符串比较运算符之后,比如:name LIKE[cd] ‘cafe’,那么不论name是cafe、Cafe还是café上面的表达式都会返回YES。

2.4 集合运算符

  • ANY、SOME:集合中任意一个元素满足条件,就返回YES。
  • ALL:集合中所有元素都满足条件,才返回YES。
  • NONE:集合中没有任何元素满足条件就返回YES。如:NONE student.age<18,表示student集合中所有元素的age>=18时,才返回YES。
  • IN:等价于SQL语句中的IN运算符,只有当左边表达式或值出现在右边的集合中才会返回YES。
运算符内容,参考自http://www.cocoachina.com/ios/20160111/14926.html

3. %K、%@、$VALUE的用法

void $VALUE_K_的用法() {    NSArray *array = @[[Student studentWithName:@"Tom" age:18 sex:1],                       [Student studentWithName:@"Jack" age:19 sex:0],                       [Student studentWithName:@"Zhuba" age:20 sex:1],                       [Student studentWithName:@"Lisi" age:100 sex:0],                       [Student studentWithName:@"Sunqi" age:0 sex:1],                       [Student studentWithName:@"Rose" age:50 sex:0]                       ];    NSMutableArray *arrayM = [array mutableCopy];    NSLog(@"%@", arrayM);    NSInteger maxAge = 50;    // ***** 这样写有语法错误!不能使用`%zd`!    // NSPredicate *pred = [NSPredicate predicateWithFormat:@"self.age >= %zd", maxAge];    NSPredicate *pred = [NSPredicate predicateWithFormat:@"self.age >= %d", maxAge];    [arrayM filterUsingPredicate:pred];    NSLog(@"%@", arrayM);    NSString *property = @"name";    NSString *value = @"Jack";    // %K 字段占位符    // %@ 值占位符    // 必须是 %K(K是大写字母)    pred = [NSPredicate predicateWithFormat:@"%K contains %@", property, value];    NSArray *tmpArray = [array filteredArrayUsingPredicate:pred];    NSLog(@"tmpArray:%@", tmpArray);    // $VALUE:VALUE只是一个普通字符串,当做标识使用,可以任意替换,但要统一!    NSPredicate *tp = [NSPredicate predicateWithFormat:@"%K > $VALUE", @"age"];    pred = [tp predicateWithSubstitutionVariables:@{@"VALUE" : @1}];    NSArray *arr1 = [array filteredArrayUsingPredicate:pred];    NSLog(@"arr1:%@", arr1);    pred = [tp predicateWithSubstitutionVariables:@{@"VALUE" : @50}];    NSArray *arr2 = [array filteredArrayUsingPredicate:pred];    NSLog(@"arr2:%@", arr2);}

4.运用举例

4.1 取出两个数组中的相同元素

void example() {    NSArray *arr1 = @[@"ab", @"abc", @1];    NSArray *arr2 = @[@"a", @"ab", @"abc", @"abcd"];    // 取出arr2中  arr2 & arr1都不包含的元素    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"NOT (SELF IN %@)", arr1];    NSLog(@"%@", [arr2 filteredArrayUsingPredicate:predicate]);    // 取出arr1 & arr2 都包含的元素    predicate = [NSPredicate predicateWithFormat:@"SELF IN %@", arr1];    NSLog(@"%@", [arr2 filteredArrayUsingPredicate:predicate]);    // 取出arr1中  arr2 & arr1都不包含的元素    predicate = [NSPredicate predicateWithFormat:@"NOT (SELF IN %@)", arr2];    NSLog(@"%@", [arr1 filteredArrayUsingPredicate:predicate]);    // array[index]:返回array数组中index索引处的元素    // array[FIRST]:返回array数组中第一个元素    // array[LAST]:返回array数组中最后一个元素    // array[SIZE]:返回array数组中元素的个数}

5.注意事项

  • %K是字段占位符(K必须大写),而%@是值占位符
  • [NSPredicate predicateWithFormat:conditon],其中如果变量condition中有占位字符,比如%@,那么如果它是什么类型,其对于的值一定也是那种类型!
  • 谓词中的占位符是*?

6.like的用法举例

  • 查询出ZTAGIDLISTM字段中有8的记录数据(ZTAGIDLISTM字段中的数据如下:1,43,8,75,88,90,3)

    • 数据库中的sql:
    ……WHERE ZTAGIDLISTM LIKE '8,%' OR ZTAGIDLISTM LIKE '%,8' OR ZTAGIDLISTM LIKE '%,8,%' OR ZTAGIDLISTM LIKE '8'
    • 使用like:
    NSString *conditon = [NSString stringWithFormat:@"tagIdListM LIKE '%@,*' OR tagIdListM LIKE '*,%@' OR tagIdListM LIKE '*,%@,*' OR tagIdListM LIKE '%@'",tagId, tagId, tagId, tagId];
0 0
原创粉丝点击