duanjian3338 2017-03-27 19:38
浏览 325
已采纳

Laravel 5.2比较字符串的日期?

I have a table that contains two dates: start_date and end_date. Both of these columns are string. When I try to query to get the records comparing against these dates, Laravel treats them as strings, instead of dates.

For example, for this query:

Schedule::whereDate('start_date','<=',date('m/d/Y'))->whereDate('end_date','>=',date('m/d/Y'))->get();

No results are returned, which is not correct.

Any thoughts? Or any other way to compare dates that are strings?

Thanks.

  • 写回答

2条回答 默认 最新

  • dpy3846 2017-03-27 19:41
    关注

    You need to make these columns datetime instead of string:

    $table->dateTime('start_date');
    $table->dateTime('end_date');
    

    Also, it's a good idea to add these columns to the $dates array:

    protected $dates = ['created_at', 'updated_at', 'start_date', 'end_date'];
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来