有两个实体:
我想制作一张类(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;
效果图:
Best Answer-推荐答案 strong>
也许是这样的?使用 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/
|