NSPredicate查询日期的问题

本文对比了两种使用NSPredicate进行日期范围查询的方法:一种是直接将日期参数传递给NSPredicate;另一种是先构造一个包含查询条件的字符串,再传递给NSPredicate。文中详细解释了为何第二种方法会导致无法解析格式字符串的错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

查询日期的时候日期可以根据参数传进去,但不能在字符串中传参后在作为查询条件

简单比较以下两段代码

    NSDate* date1=[NSDate date];
    NSDate* date2=date1;

request.predicate=[NSPredicate predicateWithFormat:@"studyDate>=%@ AND studyDate<=%@",date1,date2];
    NSDate* date1=[NSDate date];
    NSDate* date2=date1;
    _SearchString=[[NSString alloc]initWithFormat:@"studyDate>=%@ AND studyDate<=%@",date1,date2];
    request.predicate=[NSPredicate predicateWithFormat:_SearchString];

第一段代码中直接使用传参生成nspredicate,而第二段是经过了一个字符串,然后传给nspredicate,第一段代码查询没有问题,第二段代码查询就会报以下的错误

*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: 'Unable to parse the format string "studyDate>=2014-04-25 07:13:37 +0000 AND studyDate<=2014-04-25 07:13:37 +0000"'

但一般情况下查询数据库不可能是只查询一个条件,好多情况下是拼接字符串来得到一个总的查询条件,在sql语句中经常这样做,但这在谓词中不可以,我们能做的就是把所有的查询条件作为参数传到谓词中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值