Yii2中如何使用indexBy()

广告:宝塔服务器面板,一键全能部署及管理,送你10850元礼包,点我领取~~~

Yii2中如何使用indexBy()

在项目开发中经常会使用到一些特殊的值作为数组的索引,一般可以先查询出数据后数组循环拼接成所需的格式。不过YII2框架提供了一种更简单的方法indexBy()。

当你在调用all()方法时,它将返回一个以连续的整型数值为索引的数组。而有时候你可能希望使用一个特定的字段或者表达式的值来作为索引结果集数组。那么你可以在调用all()之前使用indexBy()方法来达到这个目的。例如,

// 以uid作为key值$query = User::find()    ->select(['uid', 'name'])    ->indexBy('uid')    ->asArray()    ->all();
登录后复制

查询结果如下:

{  "1001": {    "uid": "1001",    "name": "张三"  },  "1002": {    "uid": "1002",    "name": "李四"  },  "1003": {    "uid": "1003",    "name": "王五"  }}
登录后复制

如需使用表达式的值做为索引,那么只需要传递一个匿名函数给indexBy()方法即可:

// 以uid和name组合作为key值$query = User::find()    ->select(['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)在从数据库取回数据后才生效执行的。 这意味着只能使用那些在你的 SELECT 查询中的列名。 此外,你用表名连接取列名的时候,比如 customer.id,结果中将只包含 id 列,因此你必须调用 ->indexBy(‘id’) 不要带表名前缀。

推荐:《YII教程》

以上就是Yii2中如何使用indexBy()的详细内容,更多请关注9543建站博客其它相关文章!

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。

作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:如何在ThinkPHP中实现分布式应用系统
下一篇:分享通过api接口将json数据展现出来的实例教程

发表评论

关闭广告
关闭广告