【问题标题】:created_at and updated_at don't update automatically on insert in laravelcreated_at 和 updated_at 在 laravel 中插入时不会自动更新
【发布时间】:2021-11-30 07:49:23
【问题描述】:

我使用 laravel 8:

public function up()
    {
        Schema::create('user', function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->string('name');
            $table->integer('created_by')->nullable();
            $table->string('created_by_user')->nullable();
            $table->timestamps();
        });
    }

型号:

<?php

namespace App\Models\Backend\MySQL;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
    protected $table = 'user';
}

在控制器中:

use App\Models\User;

public function store(Request $request) {
    $data = [
        'name' => !empty($request->name) ? $request->name : 'Jony',
        'created_by'    => auth()->user()->id,
        'created_by_user'    => auth()->user()->name,
    ];
    User::insert($data);
}

我已成功插入。但问题是我的 created_by 和 updated_by 列没有自动更新。有什么办法可以解决这个问题。在user 模型中,我也没有设置protected $timestamps = false,但它不起作用。谢谢。

【问题讨论】:

标签: laravel


【解决方案1】:

insert 方法不适用于 eloquent 模型,并且不会更新 created_at 和 updated_at。 您应该改用 create 方法。

自动创建方法集 created_at 和 updated_at

在此处查看此答案

https://stackoverflow.com/a/58075757/7689224

【讨论】:

    【解决方案2】:

    您应该使用create 而不是insert

    User::create($data);
    

    【讨论】:

    • 您的答案可以通过额外的支持信息得到改进。请edit 添加更多详细信息,例如引用或文档,以便其他人可以确认您的答案是正确的。你可以找到更多关于如何写好答案的信息in the help center
    【解决方案3】:

    使用create() 方法代替insert()

    public function store(Request $request) {
        $data = [
            'name' => !empty($request->name) ? $request->name : 'Jony',
            'created_by'    => auth()->user()->id,
            'created_by_user'    => auth()->user()->name,
        ];
        User::create($data);
    }
    

    【讨论】:

      猜你喜欢
      • 2016-06-13
      • 2020-10-23
      • 2018-09-16
      • 1970-01-01
      • 2017-11-16
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-01-22
      相关资源
      最近更新 更多