zoukankan      html  css  js  c++  java
  • Yii2中indexBy()的使用

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

    参考Yii文档:https://www.yiichina.com/doc/guide/2.0/db-query-builder

    当你在调用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’) 不要带表名前缀。

  • 相关阅读:
    python__基础数据类型
    python基础之迭代器生成装饰器
    cat命令查看文件显示行号
    VM虚拟机安装ESD版Win10
    CentOS 8修改系统语言为中文且立即生效
    CentOS 8下yum安装LAMP环境
    完美解决CentOS8 yum安装AppStream报错,更新yum后无法makecache的问题
    鬼灭之刃高清电脑桌面壁纸
    记CentOS 8 yum 报AppStream Error排错
    CentOS 8 重启网卡命令
  • 原文地址:https://www.cnblogs.com/woods1815/p/11917694.html
Copyright © 2011-2022 走看看