1. 獲取原始屬性
當修改一條 Eloquent 模型記錄的時候你可以通過調用 getOriginal() 方法獲取記錄的原始屬性
$user = App\User::first(); $user->name; //John $user->name = "Peter"; //Peter $user->getOriginal('name'); //John $user->getOriginal(); //原始 $user 記錄
2. 檢查模型是否被修改
使用 isDirty() 方法確定模型或給定屬性是否已被修改
$user = App\User::first(); $user->isDirty(); //false $user->name = "Peter"; $user->isDirty(); //true
也可以檢查指定屬性是否被修改。
$user->isDirty('name'); //true $user->isDirty('age'); //false
3. 獲取更改的屬性
使用 getChanges() 獲取更改的屬性
$user->getChanges() //[ "name" => "Peter", ]
注:僅當您使用 syncChanges() 保存模型或同步更新時,才生效
4. 定義 deleted_at 字段
默認情況下,Laravel 使用 deleted_at 字段處理軟刪除。 您可以通過定義 DELETED_AT 屬性來更改它。
class User extends Model { use SoftDeletes; * The name of the "deleted at" column. * * @var string */ const DELETED_AT = 'is_deleted'; }
或者定義訪問
class User extends Model { use SoftDeletes; public function getDeletedAtColumn() { return 'is_deleted'; } }
5. 保存模型和關係
您可以使用 push() 方法保存模型及其關聯。
class User extends Model { public function phone() { return $this->hasOne('App\Phone'); } } $user = User::first(); $user->name = "Peter"; $user->phone->number = '1234567890'; $user->push(); // 這將更新數據庫中的用戶和電話
6. 重新加載模型
使用 fresh() 重新從數據庫加載一個模型。
$user = App\User::first(); $user->name; // John // user 表被其他進程修改。 例:數據庫又插入一條 “name” 爲 “Peter” 的數據。 $updatedUser = $user->fresh(); $updatedUser->name; // Peter $user->name; // John
7. 重新加載現有模型
你可以使用 refresh() 方法從數據庫重新加載具有新值的現有模型。
$user = App\User::first(); $user->name; // John // user 表被其他進程修改。例: “name” 被修改爲 “Peter” 。 $user->refresh(); $user->name; // Peter
注: refresh() 也會更新模型的關聯模型數據。
8. 檢查模型是否爲同一個
使用 is() 方法確定兩個模型是否擁有相同主鍵並且屬於同一張表。
$user = App\User::find(1); $sameUser = App\User::find(1); $diffUser = App\User::find(2); $user->is($sameUser); // true $user->is($diffUser); // false
9. 克隆一個模型
你可以使用 replicate() 方法來複制一個模型到一個新的對象中。
$user = App\User::find(1); $newUser = $user->replicate(); $newUser->save();
10. 在 find() 方法中指定查找的屬性
當使用 find() 或 findOrFail() 方法時,傳入第二個參數可以指定需要查找的屬性。
$user = App\User::find(1, ['name', 'age']); $user = App\User::findOrFail(1, ['name', 'age']);