我正在将我们的一个web应用程序从CodeIgniter转换为Laravel。然而,此时我们不想将updated_at / created_at字段添加到我们所有的表中,因为我们已经有一个日志类,它已经为我们更深入地完成了所有这些工作。

我知道我可以设置$timestamps = false;:

Vendor\laravel\framework\src\illuminate\Datebase\Eloquent\Model.php

然而,我宁愿不改变Laravel的核心文件,或者让我的每个模型都在顶部。有没有办法在其他地方禁用所有模型?


当前回答

如果你想从现有的模型中删除时间戳,就像前面提到的,把这个放在你的模型中:

public $timestamps = false;

在up()方法中使用以下代码创建一个迁移并运行它:

Schema::table('your_model_table', function (Blueprint $table) {
    $table->dropTimestamps();
});

您可以在down()方法中使用$table->timestamps()来允许回滚。

其他回答

雄辩的模型:

class User extends Model    
{      
    protected $table = 'users';

    public $timestamps = false;
}

或者简单地试试这个

$users = new Users();
$users->timestamps = false;
$users->name = 'John Doe';
$users->email = 'johndoe@example.com';
$users->save();

只要将Model中的公共时间戳变量声明为false,一切都将正常工作。

公共$timestamps = false;

你必须声明public $timestamps = false;在每个模型中,或者创建一个BaseModel,在那里定义它,并让所有的模型扩展它,而不是雄辩。只要记住数据透视表必须有时间戳,如果你使用雄辩。

更新:请注意,在Laravel v3之后,数据透视表不再需要时间戳。

更新:您也可以通过从迁移中删除$table->timestamps()来禁用时间戳。

如果你想从现有的模型中删除时间戳,就像前面提到的,把这个放在你的模型中:

public $timestamps = false;

在up()方法中使用以下代码创建一个迁移并运行它:

Schema::table('your_model_table', function (Blueprint $table) {
    $table->dropTimestamps();
});

您可以在down()方法中使用$table->timestamps()来允许回滚。

将这一行添加到您的模型中:

将现有变量$timestamps的true重写为false

/**
 * Indicates if the model should be timestamped.
 *
 * @var bool
 */

public $timestamps = false;