Laravel は、開発者の開発をスピードアップするための便利な機能を多数提供する非常に人気のある PHP フレームワークです。非常に重要な機能の 1 つは論理的な削除です。これにより、実際にデータベースからレコードを削除せずに、データベース内のレコードに削除済みのマークを付けることができます。この方法は、データ履歴を保存し、誤って削除するのを防ぐのに役立ちます。ただし、これらの削除されたレコードを復元する必要がある場合があります。Laravel でこれを実現するにはどうすればよいでしょうか?
まず、データ モデルが論理的な削除機能を使用していることを確認する必要があります。通常、モデルで SoftDeletes トレイトを使用して、論理的な削除機能を有効にすることができます。たとえば、User モデルで次のように記述できます。
use IlluminateDatabaseEloquentModel; use IlluminateDatabaseEloquentSoftDeletes; class User extends Model { use SoftDeletes; protected $dates = ['deleted_at']; }
その後、このモデルで論理的な削除機能を使用できます。これで、データベースで削除操作を実行できます。例:
$user = User::find(1); $user->delete();
この操作が完了したら、withTrashed メソッドを使用して、論理的に削除されたユーザー レコードを取得できます。例:
$deletedUsers = User::withTrashed() ->whereNotNull('deleted_at') ->get();
これで、論理的に削除された各ユーザー レコードの delete_at 属性にアクセスして、いつ削除されたかを知ることができます。削除されたユーザー レコードを復元する必要がある場合は、復元メソッドを使用できます。たとえば、ID 1 のユーザー レコードを復元すると仮定すると、次のように記述できます。
$user = User::withTrashed() ->where('id', 1) ->first(); $user->restore();
復元操作を実行するときは、最初に withTrashed メソッドを使用する必要があることを認識することが重要です。論理的に削除されたデータ モデル データベースから取得されます。これは、回復可能なデータは論理的に削除されたデータのみであるためです。
さらに、復元が失敗した場合に例外をスローできるrestoreOrFailメソッドを使用することもできます。例:
$user = User::withTrashed() ->where('id', 1) ->first(); try { $user->restoreOrFail(); } catch (Exception $e) { // 恢复失败 }
また、存在しない論理的に削除されたデータ モデルを復元しようとすると、例外がスローされることにも注意してください。したがって、これを回避するには、復元が失敗した場合に false を返すrestoreOnFailメソッドを使用できます。例:
$user = User::withTrashed() ->where('id', 1) ->first(); if (!$user->restoreOnFail()) { // 恢复失败 }
全体として、Laravel を使用して論理的な削除を回復するのは非常に簡単です。上記の手順に従ってください。ただし、withTrashed メソッドを使用して削除されたレコードを取得する、restore メソッドを使用して論理的に削除されたレコードを復元するなど、いくつかの詳細に注意する必要があります。これらはすべて、Laravel の論理削除機能を使用するときに注意すべきことです。
要約すると、論理的な削除を復元する手順は次のとおりです。
この記事が、読者が Laravel で論理的な削除を復元する方法をよりよく理解するのに役立つことを願っています。
以上がlaravel復元ソフト削除の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。