ホームページ > PHPフレームワーク > Laravel > Laravel ORM で created_at を有効にする 4 つの方法

Laravel ORM で created_at を有効にする 4 つの方法

リリース: 2021-08-19 09:00:45
転載
2845 人が閲覧しました

以下は Laravel フレームワーク チュートリアル コラムで、Laravel ORM で created_at のみを開くいくつかの方法を紹介します。

方法 1:

class User extends Model {
  public $timestamps = false;//关闭自动维护
  public static function boot() {
    parent::boot();
    #只添加created_at不添加updated_at
    static::creating(function ($model) {
      $model->created_at = $model->freshTimestamp();
      //$model->updated_at = $model->freshTimeStamp();
    });
  }
}
ログイン後にコピー

ここには落とし穴があります。create メソッドを使用してレコードを作成するときに返される created の値は次のとおりです:

“created_at”: {
“date”: “2020-09-27 13:47:12.000000”,
“timezone_type”: 3,
“timezone”: “Asia/Shanghai”
},
ログイン後にコピー

想像と違いました

“created_at”: “2020-09-27 13:49:39”,
ログイン後にコピー

方法 2:

class User extends Model {
  const UPDATED_AT = null;//设置update_at为null
  //const CREATED_AT = null;
}
ログイン後にコピー

ここに落とし穴があります。destroy を使用して削除するとエラーが報告されます

Missing argument 2 for Illuminate\Database\Eloquent\Model::setAttribute()
ログイン後にコピー

delete を使用しても には影響しません。

方法 3:

class User extends Model {
  //重写setUpdatedAt方法
  public function setUpdatedAt($value) {
    // Do nothing.
  }
  //public function setCreatedAt($value)
  //{
    // Do nothing.
  //}
}
ログイン後にコピー

方法 4:

class User extends Model {
  //重写setUpdatedAt方法
  public function setUpdatedAtAttribute($value) {
    // Do nothing.
  }
  //public function setCreatedAtAttribute($value)
  //{
    // Do nothing.
  //}
}
ログイン後にコピー

には影響しません。移行で設定する必要があります (具体的に試したことはありませんが、他の記事で見ました)

class CreatePostsTable extends Migration {
  public function up() {
   Schema::create('posts', function(Blueprint $table) {
   $table->timestamp('created_at')
   ->default(DB::raw('CURRENT_TIMESTAMP'));
  });
}
ログイン後にコピー

関連する推奨事項: 最新の 5 つの Laravel ビデオ チュートリアル

#

以上がLaravel ORM で created_at を有効にする 4 つの方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:杨子
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート