zoukankan      html  css  js  c++  java
  • 关于NSpredicate

            /*

             简述:Cocoa框架中的NSPredicate用于查询,原理和用法都类似于SQL中的where,作用相当于数据库的过滤取。

             定义(最常用到的方法):

             

             NSPredicate这个类有点类似于数据库中的查询,是用于在一批内容中查询符合条件的子集,中文翻译成“谓词”。这个翻译实在让我感觉很别扭,虽然明知道和谓语这个词语没什么关系,但确实总让我感觉这是一个句子里面的成分。

             

             我们有些时候会有一个对象的数组或者集合,然后希望从里面找出符合条件的集合,类似于做一次过滤操作。比如我有一批照片,希望能找出所有某一天里面拍摄的内容。

             

             NSPredicate类的创建往往使用predicateWithFormat的方法,这个方法的使用有点类似于stringWithFormat方法。

             

             */

    //查询单词里面包含“ang”的字符串

            NSArray *array = [[NSArray alloc]initWithObjects:@"beijing",@"shanghai",@"guangzou",@"wuhan", nil];

            NSString *string = @"ang";

            NSPredicate *pred = [NSPredicate predicateWithFormat:@"SELF CONTAINS %@",string];

            NSLog(@"%@",[array filteredArrayUsingPredicate:pred]);

    //查找名字里面包含“王”的姓

            NSArray *array = [[NSArray alloc]initWithObjects:@"小王",@"王力",@"李丽",@"方方", nil];

            

            NSString *match = @"*王*";

            //查找姓王的名字,王字必须为首字则修改NSString *match=@"王*";

            NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF like %@", match];

            

            NSArray *results = [array filteredArrayUsingPredicate:predicate];

            for (id str in results) {

                NSLog(@"%@",str);

            }

  • 相关阅读:
    一年足迹记录
    Scanf连续调用多次并且存在%c的问题
    Oracle学习计划
    SQL语句、PL/SQL语句、SQL*PLUS语句结束符号
    使用sys无法通过sqlplus或者sqldeveloper连接数据库
    把十进制转化为二进制的一种方法
    GTK+与QT的对比
    数据库崩溃后对redo log的使用
    产生不重复的随机牌
    失效试图,还有就是 还原试图。
  • 原文地址:https://www.cnblogs.com/wuduo/p/5120720.html
Copyright © 2011-2022 走看看