OGeek|极客世界-中国程序员成长平台

标题: ios - 核心数据 : fetch result from two entities, 和结果包含两个实体中的信息 [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-12 11:11
标题: ios - 核心数据 : fetch result from two entities, 和结果包含两个实体中的信息

有两个实体:

enter image description here

我想制作一张类(class)表。

第一个实体是Course,第二个实体是TimeAndPlace。在大学里,有一些类(class),而一门类(class)可能有不同的时间或地点。现在我想在每个工作日获取 Course 及其相关的 TimeAndPlace。但是有一些限制:如果当前周在学期开始周和上周之间,则需要该类(class);在本类(class)中,选择工作日等于某个工作日的类(class)。最后,我想获得类(class)及其相关的时间和地点。

我对 Core Data 不太熟悉,你能帮帮我吗?

已编辑: 就像 SQL:

SELECT Course.courseName, TimeAndPlace.courseLocation, TimeAndPlace.courseOrder
FROM Course, TimeAndPlace
WHERE Course.startWeekTheCourseInTheTerm <= currentWeek AND Course.lastWeekTheCourseInTheTerm >= currentWeek AND timeAndPlaces.weekday == currentweekday;

效果图:

enter image description here



Best Answer-推荐答案


也许是这样的?使用 1:n 关系并不复杂,使用 n:m 会更有趣

NSFetchRequest* fetchRequest = [[NSFetchRequest alloc] init];
[fetchRequest setEntity:[NSEntityDescription entityForName"Course" inManagedObjectContext:context]];

NSPredicate* = [NSPredicate predicateWithFormat"startWeekTheCourseInTheTerm <= %d AND lastWeekTheCourseInTheTerm >= %d AND timeAndPlaces.weekday == %d", currentWeek, currentWeek, weekday];
[fetchRequest setPredicate:predicate];

或者如果您需要完整的一周(例如在 tableView 中显示)

NSPredicate* = [NSPredicate predicateWithFormat"startWeekTheCourseInTheTerm <= %d AND lastWeekTheCourseInTheTerm >= %d", currentWeek, currentWeek];
[fetchRequest setPredicate:predicate];

[fetchRequest setSortDescriptors:[NSArray arrayWithObject:[[NSSortDescriptor alloc] initWithKey"timeAndPlaces.weekday" ascending:YES]]];

按工作日和类(class)排序:
(所以你有

-> 星期一
--> 1
--> 2
--> 3
-> 星期二
--> 1
...

[fetchRequest setSortDescriptors:[NSArray arrayWithObjects:[[NSSortDescriptor alloc] initWithKey"timeAndPlaces.weekday" ascending:YES], [[NSSortDescriptor alloc] initWithKey"timeAndPlaces.courseOrder" ascending:YES], nil]];

最后一步:获取

NSError* err = nil;
list = [NSMutableArray arrayWithArray:[context executeFetchRequest:fetchRequest error:&err]];
[fetchRequest release];

关于ios - 核心数据 : fetch result from two entities, 和结果包含两个实体中的信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16714826/






欢迎光临 OGeek|极客世界-中国程序员成长平台 (http://ogeek.cn/) Powered by Discuz! X3.4