• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Yii2 应不应该在GridView的columns里边查询把id转换成名称呢?

php 搞代码 4年前 (2022-01-23) 34次浏览 已收录 0个评论
文章目录[隐藏]

1、Yii2 ActiveDataProvider自带的分页功能,在列表使用ActiveDataProvider的时候是不需要将查询查出结果来的,平时为了方便就直接在GridView的columns里边查询把id转换成名称,但是这样的做法在查看debug的时候会出现同一条语句多次执行,影响效率。从Yii2的使用规范来讲这是不是不对?
2、如果不在GridView的columns里边查询把id转换成名称的话,又应该如何处理呢?在传到GridView前使用多表关联查询把id转换成名称的做法可好?

2本文来源gao*daima.com搞@代#码&网6

搞gaodaima代码

回复内容:

1、Yii2 ActiveDataProvider自带的分页功能,在列表使用ActiveDataProvider的时候是不需要将查询查出结果来的,平时为了方便就直接在GridView的columns里边查询把id转换成名称,但是这样的做法在查看debug的时候会出现同一条语句多次执行,影响效率。从Yii2的使用规范来讲这是不是不对?
2、如果不在GridView的columns里边查询把id转换成名称的话,又应该如何处理呢?在传到GridView前使用多表关联查询把id转换成名称的做法可好?

两种手段相结合:

  1. 在构造ActiveDataProvider时,加入with(),例如:

    <code>$query->with(['store'])->where(['name' => $something]);</code>

这样在结果集里会带上store表的内容,不必反复查询,这个应该是标准做法;

  1. 实在规避不开的,启用memcache,把结果预先保存在内存里,也可以有效地减少数据库压力。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Yii2 应不应该在GridView的columns里边查询把id转换成名称呢?
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址