淺談laravel中的關(guān)聯(lián)查詢with的問題
表結(jié)構(gòu)
主表結(jié)構(gòu):
Create Table CREATE TABLE `user` ( `uid` mediumint(8) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL, `email` varbinary(255) NOT NULL, PRIMARY KEY (`uid`) ) ENGINE=InnoDB AUTO_INCREMENT=114001 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci
附表結(jié)構(gòu):
CREATE TABLE `user_options` ( `id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT, `uid` mediumint(8) unsigned NOT NULL, `age` tinyint(3) NOT NULL, `sex` tinyint(1) NOT NULL, PRIMARY KEY (`id`), KEY `options_key` (`uid`) ) ENGINE=InnoDB AUTO_INCREMENT=114001 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci
并使用seed插入隨機(jī)數(shù)據(jù)10W條
測(cè)試
分別建立User,Options模型,并且建立一對(duì)一的關(guān)系,
代碼如下:
User::with(['options'=>function($query){
$query->where('sex','=','1');
}])->paginate(15);
laravel的debug監(jiān)控到的SQL運(yùn)行如下:
select count(*) as aggregate from `user`
select * from `user` limit 15 offset 0
select * from `user_options` where `user_options`.`uid` in ('1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14', '15') and `sex` = '1'
結(jié)論
如果是需要使用附表的過濾做列表篩選,使用with就不是很好了!
使用with的的意思,在確定主信息的時(shí)候,羅列符合條件的附表信息,適合單條或者少量主表信息或者主表信息篩選
以上這篇淺談laravel中的關(guān)聯(lián)查詢with的問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
php設(shè)計(jì)模式之職責(zé)鏈模式實(shí)例分析【星際爭(zhēng)霸游戲案例】
這篇文章主要介紹了php設(shè)計(jì)模式之職責(zé)鏈模式,結(jié)合星際爭(zhēng)霸游戲案例形式分析了php職責(zé)鏈模式相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-03-03
PHP寫UltraEdit插件腳本實(shí)現(xiàn)方法
PHP寫UltraEdit插件腳本實(shí)現(xiàn)方法,需要的朋友可以從參考下。2011-12-12
ThinkPHP5.0框架驗(yàn)證碼功能實(shí)現(xiàn)方法【基于第三方擴(kuò)展包】
這篇文章主要介紹了ThinkPHP5.0框架驗(yàn)證碼功能實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了thinkPHP5基于第三方擴(kuò)展包實(shí)現(xiàn)驗(yàn)證碼功能相關(guān)操作技巧,需要的朋友可以參考下2019-03-03
PHP內(nèi)置函數(shù)生成隨機(jī)數(shù)實(shí)例
在本篇文章里小編給大家分享了關(guān)于PHP內(nèi)置函數(shù)生成隨機(jī)數(shù)實(shí)例內(nèi)容,對(duì)此有興趣的朋友們可以學(xué)習(xí)下。2019-01-01
php處理?yè)屬?gòu)類功能的高并發(fā)請(qǐng)求
這篇文章主要為大家詳細(xì)介紹了php處理?yè)屬?gòu)類功能的高并發(fā)請(qǐng)求,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02
ThinkPHP5+Layui實(shí)現(xiàn)圖片上傳加預(yù)覽功能
這篇文章主要介紹了ThinkPHP5+Layui實(shí)現(xiàn)圖片上傳加預(yù)覽功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08
PHP判斷用戶是否已經(jīng)登錄(跳轉(zhuǎn)到不同頁(yè)面或者執(zhí)行不同動(dòng)作)
這篇文章主要介紹了PHP判斷用戶是否已經(jīng)登錄(跳轉(zhuǎn)到不同頁(yè)面或者執(zhí)行不同動(dòng)作)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
PHP守護(hù)進(jìn)程化在C和PHP環(huán)境下的實(shí)現(xiàn)
這篇文章主要介紹了PHP守護(hù)進(jìn)程化的實(shí)現(xiàn)的方法以及原理過程,以及在C環(huán)境和PHP環(huán)境下實(shí)現(xiàn)的代碼,喜歡的朋友收藏一下。2017-11-11

