成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Laravel & Lumen之Eloquent ORM使用速查-基礎(chǔ)部分

NervosNetwork / 2159人閱讀

摘要:使用時(shí),數(shù)據(jù)庫查詢構(gòu)造器的方法對(duì)模型類也是也用的,使用上只是省略了表名部分。在模型中使用成員變量指定綁定的表名。

使用Eloquent ["el?kw?nt] 時(shí),數(shù)據(jù)庫查詢構(gòu)造器的方法對(duì)模型類也是也用的,使用上只是省略了DB::table("表名")部分。

在模型中使用protected成員變量$table指定綁定的表名。


Eloquent 假設(shè)每個(gè)表都有一個(gè)名為id的主鍵,可以通過$primaryKey成員變量覆蓋該字段名稱,另外,Eloquent假設(shè)主鍵字段是自增的整數(shù),如果你想用非自增的主鍵或者非數(shù)字的主鍵的話,必須指定模型中的public屬性$incrementing為false。

默認(rèn)情況下,Eloquent期望表中存在created_atupdated_at兩個(gè)字段,字段類型為timestamp,如果不希望這兩個(gè)字段的話,設(shè)置$timestamps為false


使用protected $connection = "connection-name"指定模型采用的數(shù)據(jù)庫連接。

查詢 基本查詢操作

方法all用于返回模型表中所有的結(jié)果

$flights = Flight::all();
foreach ($flights as $flight) {
    echo $flight->name;
}

也可以使用get方法為查詢結(jié)果添加約束

$flights = AppFlight::where("active", 1)
     ->orderBy("name", "desc")
     ->take(10)
     ->get();

可以看到,查詢構(gòu)造器的方法對(duì)模型類也是可以使用的

在eloquent ORM中,getall方法查詢出多個(gè)結(jié)果集,它們的返回值是一個(gè)IlluminateDatabaseEloquentCollection對(duì)象,該對(duì)象提供了多種對(duì)結(jié)果集操作的方法

public function find($key, $default = null);
public function contains($key, $value = null);
public function modelKeys();
public function diff($items)
...

該對(duì)象的方法有很多,這里只列出一小部分,更多方法參考API文檔 Collection 和使用說明文檔。

對(duì)大量結(jié)果分段處理,同樣是使用chunk方法

Flight::chunk(200, function ($flights) {
    foreach ($flights as $flight) {
        //
    }
});
查詢單個(gè)結(jié)果

使用findfirst方法查詢單個(gè)結(jié)果,返回的是單個(gè)的模型實(shí)例

// 通過主鍵查詢模型...
$flight = AppFlight::find(1);

// 使用約束...
$flight = AppFlight::where("active", 1)->first();

使用find方法也可以返回多個(gè)結(jié)果,以Collection對(duì)象的形式返回,參數(shù)為多個(gè)主鍵

$flights = AppFlight::find([1, 2, 3]);

如果查詢不到結(jié)果的話,可以使用findOrFail或者firstOrFail方法,這兩個(gè)方法在查詢不到結(jié)果的時(shí)候會(huì)拋出IlluminateDatabaseEloquentModelNotFoundException異常

$model = AppFlight::findOrFail(1);
$model = AppFlight::where("legs", ">", 100)->firstOrFail();

如果沒有捕獲這個(gè)異常的話,laravel會(huì)自動(dòng)返回給用戶一個(gè)404的響應(yīng)結(jié)果,因此如果希望找不到的時(shí)候返回404,是可以直接使用該方法返回的

Route::get("/api/flights/{id}", function ($id) {
    return AppFlight::findOrFail($id);
});
查詢聚集函數(shù)結(jié)果

與查詢構(gòu)造器查詢方法一樣,可以使用聚集函數(shù)返回結(jié)果,常見的比如maxmin,avgsum,count

$count = AppFlight::where("active", 1)->count();
$max = AppFlight::where("active", 1)->max("price");

分頁查詢

分頁查詢可以直接使用paginate函數(shù)

LengthAwarePaginator paginate( 
    int $perPage = null, 
    array $columns = array("*"), 
    string $pageName = "page", 
    int|null $page = null
)

參數(shù)說明

參數(shù) 類型 說明
perPage int 每頁顯示數(shù)量
columns array 查詢的列名
pageName string 頁碼參數(shù)名稱
page int 當(dāng)前頁碼

返回值為 LengthAwarePaginator 對(duì)象。

$limit = 20;
$page = 1;
return Enterprise::paginate($limit, ["*"], "page", $page);

插入 基本插入操作

插入新的數(shù)據(jù)只需要?jiǎng)?chuàng)建一個(gè)新的模型實(shí)例,然后設(shè)置模型屬性,最后調(diào)用save方法即可

$flight = new Flight;
$flight->name = $request->name;
$flight->save();

在調(diào)用save方法的時(shí)候,會(huì)自動(dòng)為created_atupdated_at字段設(shè)置時(shí)間戳,不需要手動(dòng)指定

批量賦值插入

使用create方法可以執(zhí)行批量為模型的屬性賦值的插入操作,該方法將會(huì)返回新插入的模型,在執(zhí)行create方法之前,需要先在模型中指定fillableguarded屬性,用于防止不合法的屬性賦值(例如避免用戶傳入的is_admin屬性被誤錄入數(shù)據(jù)表)。

指定$fillable屬性的目的是該屬性指定的字段可以通過create方法插入,其它的字段將被過濾掉,類似于白名單,而$guarded則相反,類似于黑名單。

protected $fillable = ["name"];
// OR
protected $guarded = ["price"];

執(zhí)行create操作就只有白名單或者黑名單之外的字段可以更新了

$flight = AppFlight::create(["name" => "Flight 10"]);

除了create方法,還有兩外兩個(gè)方法可以使用firstOrNewfirstOrCreate。

firstOrCreate方法用來使用給定的列值對(duì)查詢記錄,如果查不到則插入新的。fristOrNewfirstOrCreate類似,不同在于如果不存在,它會(huì)返回一個(gè)新的模型對(duì)象,不過該模型是未經(jīng)過持久化的,需要手動(dòng)調(diào)用save方法持久化到數(shù)據(jù)庫。

// 使用屬性檢索flight,如果不存在則創(chuàng)建...
$flight = AppFlight::firstOrCreate(["name" => "Flight 10"]);

// 使用屬性檢索flight,如果不存在則創(chuàng)建一個(gè)模型實(shí)例...
$flight = AppFlight::firstOrNew(["name" => "Flight 10"]);
更新 基本更新操作

方法save不僅可以要用來插入新的數(shù)據(jù),也可以用來更新數(shù)據(jù),只需先使用模型方法查詢出要更新的數(shù)據(jù),設(shè)置模型屬性為新的值,然后再save就可以更新了,updated_at字段會(huì)自動(dòng)更新。

$flight = AppFlight::find(1);
$flight->name = "New Flight Name";
$flight->save();

也可使用update方法對(duì)多個(gè)結(jié)果進(jìn)行更新

AppFlight::where("active", 1)
    ->where("destination", "San Diego")
    ->update(["delayed" => 1]);
刪除 基本刪除操作

使用delete方法刪除模型

$flight = AppFlight::find(1);
$flight->delete();

上述方法需要先查詢出模型對(duì)象,然后再刪除,也可以直接使用主鍵刪除模型而不查詢,使用destroy方法

AppFlight::destroy(1);
AppFlight::destroy([1, 2, 3]);
AppFlight::destroy(1, 2, 3);

使用約束條件刪除,返回刪除的行數(shù)

$deletedRows = AppFlight::where("active", 0)->delete();
軟刪除

軟刪除是在表中增加deleted_at字段,當(dāng)刪除記錄的時(shí)候不會(huì)真實(shí)刪除記錄,而是設(shè)置該字段的時(shí)間戳,由Eloquent模型屏蔽已經(jīng)設(shè)置該字段的數(shù)據(jù)。

要啟用軟刪除,可以在模型中引用IlluminateDatabaseEloquentSoftDeletes這個(gè)Trait,并且在dates屬性中增加deleted_at字段。


要判斷一個(gè)模型是否被軟刪除了的話,可以使用trashed方法

if ($flight->trashed()) {
    //
}
查詢軟刪除的模型
包含軟刪除的模型

如果模型被軟刪除了,普通查詢是不會(huì)查詢到該結(jié)果的,可以使用withTrashed方法強(qiáng)制返回軟刪除的結(jié)果

$flights = AppFlight::withTrashed()
      ->where("account_id", 1)
      ->get();

// 關(guān)聯(lián)操作中也可以使用
$flight->history()->withTrashed()->get();
只查詢軟刪除的模型
$flights = AppFlight::onlyTrashed()
      ->where("airline_id", 1)
      ->get();
還原軟刪除的模型

查詢到軟刪除的模型實(shí)例之后,調(diào)用restore方法還原

$flight->restore();

也可以在查詢中使用

AppFlight::withTrashed()
    ->where("airline_id", 1)
    ->restore();

// 關(guān)聯(lián)操作中也可以使用
$flight->history()->restore();
強(qiáng)制刪除(持久化刪除)
// Force deleting a single model instance...
$flight->forceDelete();

// Force deleting all related models...
$flight->history()->forceDelete();

上述操作后,數(shù)據(jù)會(huì)被真實(shí)刪除。


參考:

Eloquent: Getting Started

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/21724.html

相關(guān)文章

  • Laravel & LumenEloquent ORM使用速查-高級(jí)部分

    摘要:使用全局作用域功能可以為模型的所有操作增加約束。提供了一些方法可以方便的來實(shí)現(xiàn)數(shù)據(jù)類型之間的轉(zhuǎn)換。要定義一個(gè),需要在模型中創(chuàng)建一個(gè)名稱為的方法,其中的是駝峰命名法的字段名。 查詢作用域 全局作用域 全局作用域允許你對(duì)給定模型的所有查詢添加約束。使用全局作用域功能可以為模型的所有操作增加約束。 軟刪除功能實(shí)際上就是利用了全局作用域功能 實(shí)現(xiàn)一個(gè)全局作用域功能只需要定義一個(gè)實(shí)現(xiàn)Illumi...

    BigNerdCoding 評(píng)論0 收藏0
  • Laravel & LumenEloquent ORM使用速查-進(jìn)階部分

    摘要:關(guān)聯(lián)關(guān)系查詢在中,所有的關(guān)系都是使用函數(shù)定義的,可以在不執(zhí)行關(guān)聯(lián)查詢的情況下獲取關(guān)聯(lián)的實(shí)例。 關(guān)聯(lián)關(guān)系 One To One 假設(shè)User模型關(guān)聯(lián)了Phone模型,要定義這樣一個(gè)關(guān)聯(lián),需要在User模型中定義一個(gè)phone方法,該方法返回一個(gè)hasOne方法定義的關(guān)聯(lián)

    Chaz 評(píng)論0 收藏0
  • Laravel & Lumen 數(shù)據(jù)庫操作速查

    摘要:在中執(zhí)行數(shù)據(jù)庫操作有兩種方式,一種是使用外觀對(duì)象的靜態(tài)方法直接執(zhí)行查詢,另外一種是使用類的靜態(tài)方法實(shí)際上也是的實(shí)現(xiàn),使用靜態(tài)訪問方式訪問的方法,內(nèi)部采用了魔術(shù)方法代理了對(duì)成員方法的訪問。在閉包函數(shù)中,如果返回,則會(huì)停止后續(xù)的處理。 在Laravel中執(zhí)行數(shù)據(jù)庫操作有兩種方式,一種是使用DB外觀對(duì)象的靜態(tài)方法直接執(zhí)行sql查詢,另外一種是使用Model類的靜態(tài)方法(實(shí)際上也是Facade...

    用戶83 評(píng)論0 收藏0
  • Lumen 初體驗(yàn)(二)

    摘要:的現(xiàn)狀目前是版本,是基于開發(fā)。入口文件啟動(dòng)文件和配置文件框架的入口文件是。在路由中指定控制器類必須寫全命名空間,不然會(huì)提示找不到類。目前支持四種數(shù)據(jù)庫系統(tǒng)以及。使用時(shí)發(fā)生錯(cuò)誤,因?yàn)樵谖募?,的默認(rèn)驅(qū)動(dòng)是。 最近使用 Lumen 做了 2 個(gè)業(yè)余項(xiàng)目,特此記錄和分享一下。 Lumen 的介紹 在使用一項(xiàng)新的技術(shù)時(shí),了解其應(yīng)用場景是首要的事情。 Lumen 的口號(hào):為速度而生的 La...

    Cheriselalala 評(píng)論0 收藏0
  • 使用 Laravel 框架開發(fā)是什么樣的體驗(yàn)

    摘要:但也因?yàn)閼?yīng)有盡有使得框架的性能比其他高性能框架低了些,為此給了幾個(gè)解決方案路由緩存經(jīng)有關(guān)部門研究,路由緩存可有效加快訪問速度以上。有朋友說框架最重要的東西是路由,我倒認(rèn)為最重要的是框架中異于其他框架且能解決痛點(diǎn)的東西,如的。 showImg(https://segmentfault.com/img/remote/1460000006767764); 在程序界的遠(yuǎn)古時(shí)期,大神們手持鍵盤敲...

    Miracle_lihb 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<