首頁 > 後端開發 > php教程 > 关于joinWith查询的疑问

关于joinWith查询的疑问

WBOY
發布: 2016-06-06 20:34:43
原創
1246 人瀏覽過

大家好,请问使用joinWith后,我看debug的sql记录,发现会多出来一条查询。

如 有表table_a、table_b关系为table_a.classid = table_b.id
使用如下查询后

<code>$query = info::find()->select(['table_a.*','table_b.name');

$query->joinWith('infoClass');
</code>
登入後複製
登入後複製

生成sql大致如下

<code>SELECT * FROM `table_a` LEFT JOIN `table_b` ON `table_a`.`classid` = `table_b`.`id`  LIMIT 20
</code>
登入後複製
登入後複製

然后会多一个查询

<code>SELECT * FROM `table_b` WHERE `id` IN ('3', '7')
</code>
登入後複製
登入後複製

问题是我之前的查询已经 获取到了table_b的内容了。
所以第二条sql 我个人认为没有必要在去查询一次数据库了。

请问大家,是如何避免这个二次查询的。 或者这个二次查询是有什么必要?

请大家解答,谢谢。

回复内容:

大家好,请问使用joinWith后,我看debug的sql记录,发现会多出来一条查询。

如 有表table_a、table_b关系为table_a.classid = table_b.id
使用如下查询后

<code>$query = info::find()->select(['table_a.*','table_b.name');

$query->joinWith('infoClass');
</code>
登入後複製
登入後複製

生成sql大致如下

<code>SELECT * FROM `table_a` LEFT JOIN `table_b` ON `table_a`.`classid` = `table_b`.`id`  LIMIT 20
</code>
登入後複製
登入後複製

然后会多一个查询

<code>SELECT * FROM `table_b` WHERE `id` IN ('3', '7')
</code>
登入後複製
登入後複製

问题是我之前的查询已经 获取到了table_b的内容了。
所以第二条sql 我个人认为没有必要在去查询一次数据库了。

请问大家,是如何避免这个二次查询的。 或者这个二次查询是有什么必要?

请大家解答,谢谢。

joinWith其实接收三个参数, 其中第二参数指定是否启用贪婪加载,它默认是 true 就是启用,也就是你所看到的,会去根据主表查询出所有的relation。

要想禁用在调用 joinWith 的时候传入第二参数,并设置为 false, 那么就不会再去执行下面的SQL了

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板