首页 > 解决方案 > 更新或创建总是创建 | 如何使用它?

问题描述

我尝试在观察者中使用 updateOrCreate 函数。所以我有这个功能:

 $transportpropremoyenaller = Transport::updateOrCreate(
        ['centre_id' => $gestionsejour->centre_id, 'allerouretour' => 
'Aller', 'date' => $gestionsejour->datedebut],
        ['ville' =>  \Config::get('constants.transport.0'), 'tarif' => '0']
    );

我在 GestionsejourObserver 中使用这个函数:

 public function created(Gestionsejour $gestionsejour)
{
    return $this->addtransportpropremoyen($gestionsejour);
}

当我创建一个新对象时,updateOrCreate 永远不会更新并总是创建一个新对象。

Gestionsejour 模型是:

 protected $fillable = [
    'datefin',
    'user_id',
    'agrement',
    'centre_id',
    'datedebut',
    'created_at',
    'updated_at',
    'deleted_at',
    'dureesejour',
    'periodesejour',
    'complet',
];

public function centre()
{
    return $this->belongsTo(Centre::class, 'centre_id');
}

public function getDatedebutAttribute($value)
{
    return $value ? Carbon::parse($value)->format(config('panel.date_format')) : null;
}

public function setDatedebutAttribute($value)
{
    $this->attributes['datedebut'] = $value ? Carbon::createFromFormat(config('panel.date_format'), $value)->format('Y-m-d') : null;
}

public function getDatefinAttribute($value)
{
    return $value ? Carbon::parse($value)->format(config('panel.date_format')) : null;
}

public function setDatefinAttribute($value)
{
    $this->attributes['datefin'] = $value ? Carbon::createFromFormat(config('panel.date_format'), $value)->format('Y-m-d') : null;
}

public function user()
{
    return $this->belongsTo(User::class, 'user_id');
}

Myabe 无法发送 3 个属性或日期有问题。我不知道。我正在阅读 laravel 文档,但不明白这个简单函数有什么问题。

标签: laravellaravel-5eloquent

解决方案


我认为您的问题在于这种方法getDatedebutAttribute 当您运行以下代码时,还使用了访问器,这意味着您正在搜索 dmy 格式,如下所示。

'date' => $gestionsejour->datedebut // '03-08-2019' <- because of getDatedebutAttribute

也许您可以创建一个辅助方法,而不是使用访问器和修改器。让模型上的数据与数据库中的数据相同。您可以在模型上做的另一件事是用 $dates 告诉哪些列是日期,因此它们将自动成为碳对象

// Model.php

/**
 * The attributes that should be mutated to dates.
 *
 * @var array
 */
protected $dates = [
    'datedebut',
];


public function formattedDateDebut()
{
    return $this->datedebut ? $this->datedebut->format('d-m-y') : null;
}

并像这样在您的视图中使用它。

{{ $gestionsejour->formattedDateDebut() }}

这样你也不再需要setDatedebutAttribute了,因为 Ymd 是你在这里使用时的默认格式'date' => $gestionsejour->datedebut


推荐阅读