如何获得日期差异

时间:2018-02-25 09:03:14

标签: php laravel-5 laravel-5.2

在laravel我正在使用它:

@php
 $ids = Session::get('id');
 $res = DB::table('user')
       ->select('dates as date')
       ->where('id','=',$user_id)
       ->get();
$date_time=$res[0]->date;
$date = new DateTime($date_time);
$now = date('Y-m-d');
$dayss_left=$date->diff($now)->format("%d");
@endphp

//In $date_time i am getting :"2018-06-28"
//And In $now getting:        "2018-02-25"  

它让我回味如下:

DateTime::diff() expects parameter 1 to be DateTimeInterface, string given

我在这里做错了任何人都可以告诉我只想要几天

1 个答案:

答案 0 :(得分:0)

您正在传递来自date的字符串。您可以创建DateTime

new DateTime($now)

您可以将代码更新为:

$dayss_left=$date->diff(new DateTime($now))->format("%d");

要以特定格式创建日期时间,请使用createfromformat

$date = DateTime::createFromFormat('Y-m-d', $date_time);