[英]Date from API call not being accepted in Laravel as a dateTime field
我正在從API調用獲取日期。 以這種方式格式化日期
2017-10-19T15:30:00
我想使用Laravel Database Migration將這個日期存儲在我的MYSQL數據庫中,目前我正在使用
$table->dateTime('datetime');
當我使用上面的dateTime字段存儲它時,我得到的只是
0000-00-00 00:00:00
當我使用時間戳格式時,我沒有得到准確的日期,只是得到了當前時間和日期。
我該如何解決? 任何幫助將不勝感激,如果您需要更多信息,請告訴我。
幸運的是,Laravel使用Carbon類,這使修改日期變得更加容易。 對於您的情況,您想這樣做:
Carbon::createFromFormat('Y-m-d\TH:i:s', $date);
有兩種方法可以實現它:可以在將其保存到數據庫之前對其進行修改,或者可以在模型上添加變量 。
public function setDatetimeAttribute($value)
{
$this->attributes['datetime'] = Carbon::createFromFormat('Y-m-d\TH:i:s', $value);
}
您可能需要進行一些驗證,以便在嘗試轉換日期/時間之前先查看其格式。
在模型中,您應該輸入:
protected $dates = ['datetime'];
使用碳
$dt = Carbon::parse('1975-05-21 22:23:00.123456');
保存:
$model = new Model;
$model->date = $dt; // you can use the carbon object directly
$model->save();
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.