千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 什么是 Laravel Eloquent Eager Loading?

什么是 Laravel Eloquent Eager Loading?

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-10-13 06:27:54 1697149674

一、什么是 Laravel Eloquent Eager Loading

Laravel Eloquent Eager Loading 是一種優(yōu)化數(shù)據(jù)庫查詢的方法,可以避免在一個循環(huán)中多次查詢數(shù)據(jù)庫而導致的性能問題。

當需要獲取一個模型及其關聯(lián)模型的數(shù)據(jù)時,如果使用常規(guī)的查詢方法,每個關聯(lián)模型都會獨立執(zhí)行一條數(shù)據(jù)庫查詢,從而導致數(shù)據(jù)庫查詢次數(shù)的增加和潛在的性能問題。而使用 Eager Loading,則可以預先加載關聯(lián)數(shù)據(jù),減少數(shù)據(jù)庫查詢次數(shù),提高性能。

它的核心是Eager Loading,它告訴Eloquent你想要抓取一個具有特定關系的模型,這樣框架就會產生一個更高效的查詢來抓取你需要的所有數(shù)據(jù)。通過快速加載,您可以將許多查詢減少到一個或兩個。

二、Eloquent 模型約定

現(xiàn)在,我們來看一個 Flight 模型的示例,我們將用它從 flights 數(shù)據(jù)庫表中檢索和存儲數(shù)據(jù)信息:

1、數(shù)據(jù)表名稱

請注意,我們并沒有告訴 Eloquent 我們的 Flight 模型使用哪個數(shù)據(jù)表。 除非明確地指定了其它名稱,否則將使用類的復數(shù)形式「蛇形命名」來作為表名。因此,在這種情況下,Eloquent 將假設 Flight 模型存儲的是 flights 數(shù)據(jù)表中的數(shù)據(jù),而 AirTrafficController 模型會將記錄存儲在 air_traffic_controllers 表中。

你可以通過在模型上定義 table 屬性來指定自定義數(shù)據(jù)表:

2、主鍵

Eloquent 也會假設每個數(shù)據(jù)表都有一個名為 id 的主鍵列。你可以定義一個受保護的 $primaryKey 屬性來重寫約定。

此外,Eloquent 假設主鍵是一個自增的整數(shù)值,這意味著默認情況下主鍵會自動轉換為 int 類型。如果您希望使用非遞增或非數(shù)字的主鍵則需要設置公共的 $incrementing 屬性設置為 false:

如果你的主鍵不是一個整數(shù),你需要將模型上受保護的 $keyType 屬性設置為 string:

3、時間戳

默認情況下,Eloquent 預期你的數(shù)據(jù)表中存在 created_at 和 updated_at 兩個字段 。如果你不想讓 Eloquent 自動管理這兩個列, 請將模型中的 $timestamps 屬性設置為 false:

如果需要自定義時間戳的格式,在你的模型中設置 $dateFormat 屬性。這個屬性決定日期屬性在數(shù)據(jù)庫的存儲方式,以及模型序列化為數(shù)組或者 JSON 的格式:

如果你需要自定義存儲時間戳的字段名,可以在模型中設置 CREATED_AT 和 UPDATED_AT 常量的值來實現(xiàn):

4、數(shù)據(jù)庫連接

默認情況下,Eloquent 模型將使用你的應用程序配置的默認數(shù)據(jù)庫連接。如果你想為模型指定一個不同的連接,設置 $connection 屬性即可:

延伸閱讀1:Laravel 的 Eloquent ORM 是什么

Laravel 的 Eloquent ORM 提供了一個漂亮、簡潔的 ActiveRecord 實現(xiàn)來和數(shù)據(jù)庫交互。每個數(shù)據(jù)庫表都有一個對應的「模型」用來與該表交互。你可以通過模型查詢數(shù)據(jù)表中的數(shù)據(jù),以及在數(shù)據(jù)表中插入新記錄。

聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉載。
10年以上業(yè)內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
mysql使用into outfile導出數(shù)據(jù),提示權限不足,怎么解決呢?

一、mysql使用into outfile導出數(shù)據(jù),提示權限不足,怎么解決將數(shù)據(jù)庫中某一表格導出:select * from 表名 into outfile ‘C:\Users\asill\Desk...詳情>>

2023-10-13 08:09:40
Mysql怎么把圖片轉換的base64以字符串的類型存入數(shù)據(jù)庫?

一、Mysql怎么把圖片轉換的base64以字符串的類型存入數(shù)據(jù)庫MySQL沒有內置功能可以實現(xiàn)此功能,但可以使用以下步驟實現(xiàn):1. 使用PHP或其他編程語...詳情>>

2023-10-13 08:05:09
為什么mysql having的條件表達式可以直接使用select后的別名?

一、為什么mysql having的條件表達式可以直接使用select后的別名SQL語句的語法順序:FROM -> WHERE -> GROUP BY -> HAVING -> SELECT -> D...詳情>>

2023-10-13 08:02:25
css為什么要放在head標簽中?

一、考慮加載順序和頁面渲染當瀏覽器加載一個網(wǎng)頁時,它會逐行解析HTML文檔,從上到下構建文檔對象模型(DOM)。DOM樹的構建過程是逐步進行的,...詳情>>

2023-10-13 07:37:19
在數(shù)據(jù)庫查詢的底層實現(xiàn)上SQL Server和MySQL的區(qū)別是什么?

一、在數(shù)據(jù)庫查詢的底層實現(xiàn)上SQL Server和MySQL的區(qū)別1.MySQL是技術外殼架構 + 插件方式存儲引擎的方式,mysql復制語法解析,SQL優(yōu)化等,然后...詳情>>

2023-10-13 07:33:43
快速通道
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
亚洲中文字永久在线 | 亚洲欧美激情在线 | 亚洲欧美综合久久久久久 | 亚洲欧美自拍另类欧美亚洲中文字 | 五月丁香六月婷婷网线视频 | 日本精品一区久久久久久 |