欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談laravel中的關(guān)聯(lián)查詢(xún)with的問(wèn)題

 更新時(shí)間:2019年10月10日 09:11:48   作者:frod-fu  
今天小編就為大家分享一篇淺談laravel中的關(guān)聯(lián)查詢(xún)with的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

表結(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é)論

如果是需要使用附表的過(guò)濾做列表篩選,使用with就不是很好了!

使用with的的意思,在確定主信息的時(shí)候,羅列符合條件的附表信息,適合單條或者少量主表信息或者主表信息篩選

以上這篇淺談laravel中的關(guān)聯(lián)查詢(xún)with的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論