zoukankan      html  css  js  c++  java
  • coredata中谓词的使用

    Cocoa提供了一个类NSPredicate类,该类主要用于指定过滤器的条件,该对象可以准确的描述所需条件,对每个对象通过谓词进行筛选,判断是否与条件相匹配。谓词表示计算真值或假值的函数。在cocoa中封装的一个数据库框架cocoaData里面 在进行查询(包括模糊查询)时同样会要用到谓词;下面对谓词的使用方法及规则进行简要的介绍下:

    1,用predicateWithFormat创建一个谓词

    • 条件

           NSString *predicateString =@"name=='Herbie'"

           NSString *predicateString =@"engine.horsepower > 150" 属性值

           NSString *predicateString =@"(engine.horsepower > 50) AND (engine.horsepower     < 200)";可以运用运算符

           NSString *predicateString =@"engine.horsepower BETWEEN { 50, 200 }";这里可以运用between关键字。和上面效果一样

           NSString *predicateString =@"name IN { 'Herbie', 'Snugs', 'Badger', 'Flap' }";包含在其中用IN

           NSString *predicateString =@"name BEGINSWITH 'Bad'";字符串运算符BEGINSWITH,ENDSWITH,CONTAINS[c][d][cd]

               BEGINSWITH:检查某个字符串是否以另一个字符串开头。

               ENDSWITH:检查某个字符串是否以另一个字符串结尾。

               CONTAINS:检查某个字符串是否以另一个字符串内部。

               [c]不区分大小写[d]不区分发音符号即没有重音符号[cd]既不区分大小写,又不区分发音符号。

    • 创建谓词

           NSPredicate *predicate=[NSPredicate predicateWithFormat:predicateString]

           results = [cars filteredArrayUsingPredicate: predicate];

           NSLog (@"%@", results);

    • like的使用

           predicate = [NSPredicate predicateWithFormat:@"name LIKE[cd] '*er*'"];//*代表通配符Like还接受[cd].

           results = [cars filteredArrayUsingPredicate: predicate];

           NSLog (@"%@", results);

           predicate = [NSPredicate predicateWithFormat:@"name LIKE[cd] '???er*'"];//?只匹配一个字符并且还可以接受[cd].

           results = [cars filteredArrayUsingPredicate: predicate];

           NSLog (@"%@", results);

    感谢大神

  • 相关阅读:
    使用parted 对大容量盘进行分区
    CENTOS7 修改网卡名称为eth[012...],格式
    docker报错
    docker 存储定义成direct-lvm 模式
    Docker存储方式选型建议
    centos install docker setup centos7 安装docker
    docker centos yum 源
    zip 解压脚本
    IaaS,PaaS,Saas 云服务的介绍
    Codeforces Round #589 (Div. 2) D. Complete Tripartite(模拟)
  • 原文地址:https://www.cnblogs.com/isItOk/p/5357372.html
Copyright © 2011-2022 走看看