10 個你可能不知道的 Laravel Eloquent 小技巧
阿新 • • 發佈:2020-11-27
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']);