摘要:使用時,數據庫查詢構造器的方法對模型類也是也用的,使用上只是省略了表名部分。在模型中使用成員變量指定綁定的表名。
使用Eloquent ["el?kw?nt] 時,數據庫查詢構造器的方法對模型類也是也用的,使用上只是省略了DB::table("表名")部分。
在模型中使用protected成員變量$table指定綁定的表名。
Eloquent 假設每個表都有一個名為id的主鍵,可以通過$primaryKey成員變量覆蓋該字段名稱,另外,Eloquent假設主鍵字段是自增的整數,如果你想用非自增的主鍵或者非數字的主鍵的話,必須指定模型中的public屬性$incrementing為false。
默認情況下,Eloquent期望表中存在created_at和updated_at兩個字段,字段類型為timestamp,如果不希望這兩個字段的話,設置$timestamps為false
使用protected $connection = "connection-name"指定模型采用的數據庫連接。
查詢 基本查詢操作方法all用于返回模型表中所有的結果
$flights = Flight::all(); foreach ($flights as $flight) { echo $flight->name; }也可以使用get方法為查詢結果添加約束
$flights = AppFlight::where("active", 1) ->orderBy("name", "desc") ->take(10) ->get();可以看到,查詢構造器的方法對模型類也是可以使用的
在eloquent ORM中,get和all方法查詢出多個結果集,它們的返回值是一個IlluminateDatabaseEloquentCollection對象,該對象提供了多種對結果集操作的方法
public function find($key, $default = null); public function contains($key, $value = null); public function modelKeys(); public function diff($items) ...該對象的方法有很多,這里只列出一小部分,更多方法參考API文檔 Collection 和使用說明文檔。
對大量結果分段處理,同樣是使用chunk方法
Flight::chunk(200, function ($flights) { foreach ($flights as $flight) { // } });查詢單個結果使用find和first方法查詢單個結果,返回的是單個的模型實例
// 通過主鍵查詢模型... $flight = AppFlight::find(1); // 使用約束... $flight = AppFlight::where("active", 1)->first();使用find方法也可以返回多個結果,以Collection對象的形式返回,參數為多個主鍵
$flights = AppFlight::find([1, 2, 3]);如果查詢不到結果的話,可以使用findOrFail或者firstOrFail方法,這兩個方法在查詢不到結果的時候會拋出IlluminateDatabaseEloquentModelNotFoundException異常
$model = AppFlight::findOrFail(1); $model = AppFlight::where("legs", ">", 100)->firstOrFail();如果沒有捕獲這個異常的話,laravel會自動返回給用戶一個404的響應結果,因此如果希望找不到的時候返回404,是可以直接使用該方法返回的
Route::get("/api/flights/{id}", function ($id) { return AppFlight::findOrFail($id); });查詢聚集函數結果與查詢構造器查詢方法一樣,可以使用聚集函數返回結果,常見的比如max, min,avg,sum,count等
$count = AppFlight::where("active", 1)->count(); $max = AppFlight::where("active", 1)->max("price");分頁查詢分頁查詢可以直接使用paginate函數
LengthAwarePaginator paginate( int $perPage = null, array $columns = array("*"), string $pageName = "page", int|null $page = null )參數說明
參數 | 類型 | 說明 |
---|---|---|
perPage | int | 每頁顯示數量 |
columns | array | 查詢的列名 |
pageName | string | 頁碼參數名稱 |
page | int | 當前頁碼 |
返回值為 LengthAwarePaginator 對象。
$limit = 20; $page = 1; return Enterprise::paginate($limit, ["*"], "page", $page);插入 基本插入操作
插入新的數據只需要創建一個新的模型實例,然后設置模型屬性,最后調用save方法即可
$flight = new Flight; $flight->name = $request->name; $flight->save();
批量賦值插入在調用save方法的時候,會自動為created_at和updated_at字段設置時間戳,不需要手動指定
使用create方法可以執行批量為模型的屬性賦值的插入操作,該方法將會返回新插入的模型,在執行create方法之前,需要先在模型中指定fillable和guarded屬性,用于防止不合法的屬性賦值(例如避免用戶傳入的is_admin屬性被誤錄入數據表)。
指定$fillable屬性的目的是該屬性指定的字段可以通過create方法插入,其它的字段將被過濾掉,類似于白名單,而$guarded則相反,類似于黑名單。
protected $fillable = ["name"]; // OR protected $guarded = ["price"];
執行create操作就只有白名單或者黑名單之外的字段可以更新了
$flight = AppFlight::create(["name" => "Flight 10"]);
除了create方法,還有兩外兩個方法可以使用firstOrNew和firstOrCreate。
firstOrCreate方法用來使用給定的列值對查詢記錄,如果查不到則插入新的。fristOrNew與firstOrCreate類似,不同在于如果不存在,它會返回一個新的模型對象,不過該模型是未經過持久化的,需要手動調用save方法持久化到數據庫。
// 使用屬性檢索flight,如果不存在則創建... $flight = AppFlight::firstOrCreate(["name" => "Flight 10"]); // 使用屬性檢索flight,如果不存在則創建一個模型實例... $flight = AppFlight::firstOrNew(["name" => "Flight 10"]);更新 基本更新操作
方法save不僅可以要用來插入新的數據,也可以用來更新數據,只需先使用模型方法查詢出要更新的數據,設置模型屬性為新的值,然后再save就可以更新了,updated_at字段會自動更新。
$flight = AppFlight::find(1); $flight->name = "New Flight Name"; $flight->save();
也可使用update方法對多個結果進行更新
AppFlight::where("active", 1) ->where("destination", "San Diego") ->update(["delayed" => 1]);刪除 基本刪除操作
使用delete方法刪除模型
$flight = AppFlight::find(1); $flight->delete();
上述方法需要先查詢出模型對象,然后再刪除,也可以直接使用主鍵刪除模型而不查詢,使用destroy方法
AppFlight::destroy(1); AppFlight::destroy([1, 2, 3]); AppFlight::destroy(1, 2, 3);
使用約束條件刪除,返回刪除的行數
$deletedRows = AppFlight::where("active", 0)->delete();軟刪除
軟刪除是在表中增加deleted_at字段,當刪除記錄的時候不會真實刪除記錄,而是設置該字段的時間戳,由Eloquent模型屏蔽已經設置該字段的數據。
要啟用軟刪除,可以在模型中引用IlluminateDatabaseEloquentSoftDeletes這個Trait,并且在dates屬性中增加deleted_at字段。
要判斷一個模型是否被軟刪除了的話,可以使用trashed方法
if ($flight->trashed()) { // }查詢軟刪除的模型包含軟刪除的模型
如果模型被軟刪除了,普通查詢是不會查詢到該結果的,可以使用withTrashed方法強制返回軟刪除的結果
$flights = AppFlight::withTrashed() ->where("account_id", 1) ->get(); // 關聯操作中也可以使用 $flight->history()->withTrashed()->get();只查詢軟刪除的模型
$flights = AppFlight::onlyTrashed() ->where("airline_id", 1) ->get();還原軟刪除的模型
查詢到軟刪除的模型實例之后,調用restore方法還原
$flight->restore();也可以在查詢中使用
AppFlight::withTrashed() ->where("airline_id", 1) ->restore(); // 關聯操作中也可以使用 $flight->history()->restore();強制刪除(持久化刪除)
// Force deleting a single model instance... $flight->forceDelete(); // Force deleting all related models... $flight->history()->forceDelete();上述操作后,數據會被真實刪除。
參考:
Eloquent: Getting Started
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/21724.html
摘要:使用全局作用域功能可以為模型的所有操作增加約束。提供了一些方法可以方便的來實現數據類型之間的轉換。要定義一個,需要在模型中創建一個名稱為的方法,其中的是駝峰命名法的字段名。 查詢作用域 全局作用域 全局作用域允許你對給定模型的所有查詢添加約束。使用全局作用域功能可以為模型的所有操作增加約束。 軟刪除功能實際上就是利用了全局作用域功能 實現一個全局作用域功能只需要定義一個實現Illumi...
摘要:關聯關系查詢在中,所有的關系都是使用函數定義的,可以在不執行關聯查詢的情況下獲取關聯的實例。 關聯關系 One To One 假設User模型關聯了Phone模型,要定義這樣一個關聯,需要在User模型中定義一個phone方法,該方法返回一個hasOne方法定義的關聯
摘要:在中執行數據庫操作有兩種方式,一種是使用外觀對象的靜態方法直接執行查詢,另外一種是使用類的靜態方法實際上也是的實現,使用靜態訪問方式訪問的方法,內部采用了魔術方法代理了對成員方法的訪問。在閉包函數中,如果返回,則會停止后續的處理。 在Laravel中執行數據庫操作有兩種方式,一種是使用DB外觀對象的靜態方法直接執行sql查詢,另外一種是使用Model類的靜態方法(實際上也是Facade...
摘要:的現狀目前是版本,是基于開發。入口文件啟動文件和配置文件框架的入口文件是。在路由中指定控制器類必須寫全命名空間,不然會提示找不到類。目前支持四種數據庫系統以及。使用時發生錯誤,因為在文件中,的默認驅動是。 最近使用 Lumen 做了 2 個業余項目,特此記錄和分享一下。 Lumen 的介紹 在使用一項新的技術時,了解其應用場景是首要的事情。 Lumen 的口號:為速度而生的 La...
摘要:但也因為應有盡有使得框架的性能比其他高性能框架低了些,為此給了幾個解決方案路由緩存經有關部門研究,路由緩存可有效加快訪問速度以上。有朋友說框架最重要的東西是路由,我倒認為最重要的是框架中異于其他框架且能解決痛點的東西,如的。 showImg(https://segmentfault.com/img/remote/1460000006767764); 在程序界的遠古時期,大神們手持鍵盤敲...
閱讀 466·2021-10-09 09:57
閱讀 470·2019-08-29 18:39
閱讀 811·2019-08-29 12:27
閱讀 3028·2019-08-26 11:38
閱讀 2667·2019-08-26 11:37
閱讀 1286·2019-08-26 10:59
閱讀 1377·2019-08-26 10:58
閱讀 989·2019-08-26 10:48