2014-08-31 69 views

回答

0

$query = DB::query("select concat(date," ",time) as datetime from TABLENAME");使用此行查詢,您可以連接日期和時間DB值;它會像日期時間值一樣工作。

0

您可以使用增變了這一點:

// assuming your date field is in format Y-m-d and time H:i:s 
// and you want the property named someTimestamp 

public function getSomeTimestampAttribute() 
{ 
    // use Carbon\Carbon for the class 
    return new Carbon($this->attributes['date'] . ' ' . $this->attributes['time']); 
} 

public function setSomeTimestampAttribute($dateTime) 
{ 
    // parse param to get string 'Y-m-d H:i:s' 
    $dateTime = $this->fromDateTime($dateTime); 

    $date = substr($dateTime, 0, 10); // Y-m-d 
    $time = substr($dateTime, 11); // H:i:s 

    $this->attributes['date'] = $date; 
    $this->attributes['time'] = $time; 
} 

然後,你可以這樣做:

// get 
$model->someTimestamp; // Carbon instance depending on date & time db fields 
$model->someTimestamp->diff(Carbon::now()); 

// set - all methods do the same 
$model->someTimestamp = new Carbon('2014-08-31 11:55:00'); 
$model->someTimestamp = new DateTime('2014-08-31 11:55:00'); 
$model->someTimestamp = '2014-08-31 11:55:00'; 

// then this is true 
$model->date; // 2014-08-31 
$model->time; // 11:55:00 
// so you can now call ->save() on the model and values in db will be correct 
0

串聯兩個變量存儲是不夠的,它需要更多。我使用Laravel,所以在我的情況下,這並獲得成功:

$datetime = $date.' '.$time; 
    $datetime = new DateTime($datetime); 

所有我需要的是一個DateTime對象,這是我得到了它。因此,在此之後,我可以輕鬆獲得兩個DateTime對象之間的區別。

$currentDateTime = new DateTime(); //Returns current time & date in a DateTime object 
    $difference = $currentDateTime->diff($datetime); 

$ difference有所有我想要的。

相關問題