在项目开发中经常会使用到一些形容的成语特殊的值作为数组的索引,一般可以先查询出数据后数组循环拼接成所需的格式。不过yii2框架提供了一种更简单的方法indexby()。
参考yii文档:
当你在调用all()方法时,它将返回一个以连续的整型数值为索引的数组。
而有时候你可能希望使用一个特定的字安全知识教育段或者表达式的值来作为索引结果集数组。那么你可以在调用all()之前使用indexby()方法来达到这个目的。
例如,
// 以uid作为key值$query = ur::find() ->lect(['uid', 'name']) ->indexby('uid') ->asarray() ->all();
查询结果如下:
{ "1001": { "uid": "1001", "name": "张三" }, "1002": { "uid": "1002", 职业理想怎么写"name": "李四" }, "1003": { "uid": "1003", "name": "王五" }}
如需使用表达式的值做为索引,那么只需要传递一个匿名函数给indexby()方法即可:
// 以uid和name组合作为key值$query = ur::find() ->lect(['uid', 'name']) ->indexby(function ($row) { return $row['uid'] . $row['name']; // row中使用的字段名只能是查询返回的字段名 }) ->asarray() ->all();
查询结果如下:
{ "1001张三": { "uid": "1001", "name": "张三" }, "1002李四": { "uid": "1002", "name": "李四" }, "1003王五": { "uid": "1003", "梦见一条大蟒蛇name": "王五" }}
注意: 与 groupby() 或者 orderby() 等查询方法不同, 他们将转换为 sql 查询语句的一部分,而这个方法(indexby)在从数据库取回数据后才生效执行的。 这意味着只能使用那些在你的 lect 查询中的列名。 此外,你用表名连接取列名的繁体qq时候,比如 customer.id,结果中将只包含 id 列,因此你必须调用 ->indexby(‘id’) 不要带表名前缀。
本文发布于:2023-04-07 22:09:09,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/13b3282fa262627bc522233f02717395.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:Yii2中indexBy()的使用.doc
本文 PDF 下载地址:Yii2中indexBy()的使用.pdf
留言与评论(共有 0 条评论) |