簡體   English   中英

Laravel中不接受來自API調用的日期作為dateTime字段

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM