请教一个问题,当我们用 Laravel 联表查询的时候,开销是什么样的?

比如主表有500条记录,副表有1000条记录,时间复杂度是多少?

return $this->hasOne('/User','article_id','id');

另外,为什么从表的关联键最好设置为主键id?

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

如无变动,Laravel 5.8 的版本是用 where exists 实现这个关联查询的。

你可以安装 Telescope 监听每个调用实际产生的 SQL 语句,放到 MySQL 查询器中用 Explain 命令分析一下查询计划,就可以预估时间复杂度和空间复杂度

5年前 评论
wwzh (楼主) 5年前
讨论数量: 1

如无变动,Laravel 5.8 的版本是用 where exists 实现这个关联查询的。

你可以安装 Telescope 监听每个调用实际产生的 SQL 语句,放到 MySQL 查询器中用 Explain 命令分析一下查询计划,就可以预估时间复杂度和空间复杂度

5年前 评论
wwzh (楼主) 5年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!