multiday-all 天事件的 NSPredicate

NSPredicate for multiday-all day event

在我的数据库中,我有两列,即 startDate 和 endDate,如果用户在 UI 中按下任何日期,比如 2015 年 7 月 16 日,那么它应该获取介于 startDate 和 endDate 之间的所有事件。

之前我写了一个谓词来获取凝视事件:

[NSPredicate predicateWithFormat:[NSString stringWithFormat:@"%@ >= %%@ AND %@ < %%@", @"startTime", @"endTime"], date, [date dateForNextDay]]

但如果给定日期不是事件的开始日期,上述查询将不起作用。

示例: 如果我的会议日期为 7/13 - 7/16 并且给定日期为 7/14,则会议事件应该能够使用谓词获取。我的旧查询仅适用于 7 月 13 日。它应该在给定日期获取该事件 - 7/13、7/14、7/15、7/16

我不明白你为什么有两个日期:date 和 dateForNextDay。

我认为你应该试试这个: [NSPredicate predicateWithFormat:@"startTime >= %@ && %@ < endTime", date, [date ForNextDay]];

或者像这样切换最后一个 %@%%@ => @"%@ > = %%@ 和 %%@ < %@"

编辑:顺便说一句,正如 @danh 所说,您可能只想使用日期,日期。

Edit2:好的,我回答得太快了,所有条件都是假的,danh 又是对的 ;) @"startTime <= %@ && %@ <= endTime"

获取给定日期大于或等于和小于或等于给定日期的事件....

[NSPredicate predicateWithFormat:@"%@ >= startTime AND %@ <= endTime", date, date]

编辑... 用一个简单的对象测试这个确认它工作正常....

- (NSArray *)filterArray:(NSArray *)array forDate:(NSDate *)date {
    NSPredicate *p = [NSPredicate predicateWithFormat:@"%@ >= startTime AND %@ <= endTime", date, date];
    return [array filteredArrayUsingPredicate:p];
}

- (void)testPredicate {

    NSDictionary *event0 = @{ @"startTime":[self dateFromString:@"07/01/2015"], @"endTime":[self dateFromString:@"07/04/2015"] };
    NSDictionary *event1 = @{ @"startTime":[self dateFromString:@"07/10/2015"], @"endTime":[self dateFromString:@"07/14/2015"] };
    NSDictionary *event2 = @{ @"startTime":[self dateFromString:@"08/02/2015"], @"endTime":[self dateFromString:@"08/09/2015"] };

    NSArray *events = @[event0, event1, event2];

    NSDate *july9 = [self dateFromString:@"07/09/2015"];
    NSDate *july10 = [self dateFromString:@"07/10/2015"];
    NSDate *july11 = [self dateFromString:@"07/11/2015"];
    NSDate *july13 = [self dateFromString:@"07/13/2015"];
    NSDate *july14 = [self dateFromString:@"07/14/2015"];
    NSDate *july15 = [self dateFromString:@"07/15/2015"];

    NSLog(@"filtered using 9 should be empty %@", [self filterArray:events forDate:july9]);
    NSLog(@"filtered using 10 should hit %@", [self filterArray:events forDate:july10]);
    NSLog(@"filtered using 11 should hit %@", [self filterArray:events forDate:july11]);
    NSLog(@"filtered using 13 should hit %@", [self filterArray:events forDate:july13]);
    NSLog(@"filtered using 14 should hit %@", [self filterArray:events forDate:july14]);
    NSLog(@"filtered using 15 should be empty %@", [self filterArray:events forDate:july15]);
}

- (NSDate *)dateFromString:(NSString *)string {
    NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];
    [dateFormatter setDateFormat:@"MM/dd/yyyy"];
    return [dateFormatter dateFromString:string];
}

上述内容不需要对午夜情况进行特殊处理即可按照问题建议执行(包括最后一个 endTime)。

这会生成以下日志输出,您可以自己确认...

filtered using 9 should be empty ()
filtered using 10 should hit (
        {
        endTime = "2015-07-14 07:00:00 +0000";
        startTime = "2015-07-10 07:00:00 +0000";
    }
)
filtered using 11 should hit (
        {
        endTime = "2015-07-14 07:00:00 +0000";
        startTime = "2015-07-10 07:00:00 +0000";
    }
)
filtered using 13 should hit (
        {
        endTime = "2015-07-14 07:00:00 +0000";
        startTime = "2015-07-10 07:00:00 +0000";
    }
)
filtered using 14 should hit (
        {
        endTime = "2015-07-14 07:00:00 +0000";
        startTime = "2015-07-10 07:00:00 +0000";
    }
)
filtered using 15 should be empty ()