使用CoreData查询数据:谓词过滤,排序操作
2017-03-15 17:42
766 查看
主要是对于NSPredicate的介绍:一、NSPredicate的基本语法;二
使用CoreData查询数据:谓词过滤,排序操作
一、NSPredicate的基本语法
NSPredicate类是用来定义逻辑条件约束的获取或内存中的过滤搜索。
可以使用谓词来表示逻辑条件,用于描述对象持久性存储在内存中的对象过滤。其实意思就是:我是一个过滤器,不符合条件的都滚开。
我们使用一门语言,无论是外语还是计算机语言,总是从语法开始的,这样我们才能正确的把握逻辑。所以我们从语法开始说起。在这部分我们仅关心其语法的使用
只要我们使用谓词(NSPredicate)都需要为谓词定义谓词表达式,而这个表达式必须是一个返回BOOL的值。
谓词表达式由表达式、运算符和值构成。
详细内容查看来源:http://www.cocoachina.com/ios/20160111/14926.html
二 使用CoreData查询数据:谓词过滤,排序操作
- (void)_query
{
// 初始化查询请求
// NSFetchRequest * request = [[NSFetchRequest alloc] initWithEntityName:@"Student"];
// 调用的是上下文的方法
// 方法一
// 通过父类的KVC方式查询
// NSArray * array = [self.context executeFetchRequest:request error:nil];
// for (NSManagedObject * student in array)
// {
// NSLog(@"%@--- %i", [student valueForKey:@"name"], [[student valueForKey:@"age"] intValue]);
// }
// 方法二
// 通过映射对象获取(常用)
// NSArray * array = [self.context executeFetchRequest:request error:nil];
// for (Student * student in array)
// {
// NSLog(@"%@--- %i", student.name, [student.age intValue]);
// }
//// 方法三
//// 通过子类的KVC方式查询
// NSArray * array = [self.context executeFetchRequest:request error:nil];
// for (Student * student in array)
// {
// NSLog(@"%@--- %i", [student valueForKey:@"name"], [[student valueForKey:@"age"] intValue]);
// }
// 谓词过滤
// 过滤其他查询
// 1、<,>,=
//// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = lisi"];//错误写法
//// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = %@", @"lisi"];//正确写法
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = 'lisi'"];//正确写法
// request.predicate = predict;//不赋值就是对全部内容操作
// 2.like
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name like %@", @"*lisi*"];//注意使用的是*
// request.predicate = predict;
// 3.and,or
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = 'lisi' and age = 56"];
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = %@ and age = %i", @"lisi", 56];
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = %@ && age = %i", @"lisi", 56];
// request.predicate = predict;
// 4.in
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name in%@", @[@"lisi", @"zhangsanlisi"]];
// request.predicate = predict;
// 5.between
// 使用字符串的方式
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"age between {0,120}"];
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"age BETWEEN {0,120}"];
// 或者使用数组的方式
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"age between %@", @[@22, @24]];//两个数倒过来就查不出来了
// predict = [NSPredicate predicateWithFormat:predict.predicateFormat];
// NSLog(@"%@", predict.predicateFormat);//打印predict的字符串
// request.predicate = predict;
//
// 排序
// NSSortDescriptor * sort = [NSSortDescriptor sortDescriptorWithKey:@"age" ascending:NO];
// request.sortDescriptors = @[sort];//数组中可以放置多个sort,一般就用一个
// 打印返回的结果
// NSArray * array = [self.context executeFetchRequest:request error:nil];
// for (Student * student in array) {
// NSLog(@"%@-- %i", student.name, [student.age intValue]);
// }
}
使用CoreData查询数据:谓词过滤,排序操作
一、NSPredicate的基本语法
NSPredicate类是用来定义逻辑条件约束的获取或内存中的过滤搜索。
可以使用谓词来表示逻辑条件,用于描述对象持久性存储在内存中的对象过滤。其实意思就是:我是一个过滤器,不符合条件的都滚开。
我们使用一门语言,无论是外语还是计算机语言,总是从语法开始的,这样我们才能正确的把握逻辑。所以我们从语法开始说起。在这部分我们仅关心其语法的使用
只要我们使用谓词(NSPredicate)都需要为谓词定义谓词表达式,而这个表达式必须是一个返回BOOL的值。
谓词表达式由表达式、运算符和值构成。
详细内容查看来源:http://www.cocoachina.com/ios/20160111/14926.html
二 使用CoreData查询数据:谓词过滤,排序操作
- (void)_query
{
// 初始化查询请求
// NSFetchRequest * request = [[NSFetchRequest alloc] initWithEntityName:@"Student"];
// 调用的是上下文的方法
// 方法一
// 通过父类的KVC方式查询
// NSArray * array = [self.context executeFetchRequest:request error:nil];
// for (NSManagedObject * student in array)
// {
// NSLog(@"%@--- %i", [student valueForKey:@"name"], [[student valueForKey:@"age"] intValue]);
// }
// 方法二
// 通过映射对象获取(常用)
// NSArray * array = [self.context executeFetchRequest:request error:nil];
// for (Student * student in array)
// {
// NSLog(@"%@--- %i", student.name, [student.age intValue]);
// }
//// 方法三
//// 通过子类的KVC方式查询
// NSArray * array = [self.context executeFetchRequest:request error:nil];
// for (Student * student in array)
// {
// NSLog(@"%@--- %i", [student valueForKey:@"name"], [[student valueForKey:@"age"] intValue]);
// }
// 谓词过滤
// 过滤其他查询
// 1、<,>,=
//// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = lisi"];//错误写法
//// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = %@", @"lisi"];//正确写法
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = 'lisi'"];//正确写法
// request.predicate = predict;//不赋值就是对全部内容操作
// 2.like
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name like %@", @"*lisi*"];//注意使用的是*
// request.predicate = predict;
// 3.and,or
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = 'lisi' and age = 56"];
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = %@ and age = %i", @"lisi", 56];
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name = %@ && age = %i", @"lisi", 56];
// request.predicate = predict;
// 4.in
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"name in%@", @[@"lisi", @"zhangsanlisi"]];
// request.predicate = predict;
// 5.between
// 使用字符串的方式
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"age between {0,120}"];
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"age BETWEEN {0,120}"];
// 或者使用数组的方式
// NSPredicate * predict = [NSPredicate predicateWithFormat:@"age between %@", @[@22, @24]];//两个数倒过来就查不出来了
// predict = [NSPredicate predicateWithFormat:predict.predicateFormat];
// NSLog(@"%@", predict.predicateFormat);//打印predict的字符串
// request.predicate = predict;
//
// 排序
// NSSortDescriptor * sort = [NSSortDescriptor sortDescriptorWithKey:@"age" ascending:NO];
// request.sortDescriptors = @[sort];//数组中可以放置多个sort,一般就用一个
// 打印返回的结果
// NSArray * array = [self.context executeFetchRequest:request error:nil];
// for (Student * student in array) {
// NSLog(@"%@-- %i", student.name, [student.age intValue]);
// }
}
相关文章推荐
- 使用CoreData查询数据:谓词过滤,排序操作
- sparkSQL里 sql语句,dataframe,Thrift Server JDBC都可以实现对数据的查询,过滤等操作, 哪这3种情况分别是什么情况下使用
- Scott Mitchell 的ASP.NET 2.0数据操作教程之八:使用两个DropDownList过滤的主/从报表
- Scott Mitchell 的ASP.NET 2.0数据操作教程之七:使用DropDownList过滤的主/从报表
- JPA学习笔记---JPA数据的操作:增加,删除,修改,获取,使用JPQL进行查询
- T-SQL操作语句之数据查询(二):查询中使用函数
- Scott Mitchell 的ASP.NET 2.0数据操作教程之七:使用DropDownList过滤的主/从报表
- 使用PDF.NET数据开发框架的实体操作语言OQL构造复杂查询条件
- 开始VS 2012中LightSwitch系列的第4部分:太多信息了!使用查询来排序和筛选数据
- coredata 快速过滤查询 再次封装 是coredata更加容易操作https://github.com/halostatue/coredhalostatue/coredata-easyfetch
- SQL应用与开发:(七)数据操作 · 查 · (三)使用子查询访问和修改数据
- Scott Mitchell 的ASP.NET 2.0数据操作教程之八:使用两个DropDownList过滤的主/从报表
- Scott Mitchell 的ASP.NET 2.0数据操作教程之七:使用DropDownList过滤的主/从报表
- 使用ajax来实现数据的添加删除查询并能操作表格
- 【EntityFramework系列教程三,翻译】在ASP.NET MVC程序中使用EntityFramework对数据进行排序、过滤筛选以及实现分页
- Scott Mitchell 的ASP.NET 2.0数据操作教程之八:使用两个DropDownList过滤的主/从报表
- j2se使用数据模型和JTable完成数据库读取和查询操作
- Scott Mitchell 的ASP.NET 2.0数据操作教程之八:使用两个DropDownList过滤的主/从报表
- 使用mybatis查询数据,按特定顺序排序
- 使用C#对MongoDB中的数据进行查询,修改等操作