1. <i id='AZk1E'><tr id='AZk1E'><dt id='AZk1E'><q id='AZk1E'><span id='AZk1E'><b id='AZk1E'><form id='AZk1E'><ins id='AZk1E'></ins><ul id='AZk1E'></ul><sub id='AZk1E'></sub></form><legend id='AZk1E'></legend><bdo id='AZk1E'><pre id='AZk1E'><center id='AZk1E'></center></pre></bdo></b><th id='AZk1E'></th></span></q></dt></tr></i><div id='AZk1E'><tfoot id='AZk1E'></tfoot><dl id='AZk1E'><fieldset id='AZk1E'></fieldset></dl></div>

      <tfoot id='AZk1E'></tfoot>
    2. <small id='AZk1E'></small><noframes id='AZk1E'>

        <bdo id='AZk1E'></bdo><ul id='AZk1E'></ul>
      <legend id='AZk1E'><style id='AZk1E'><dir id='AZk1E'><q id='AZk1E'></q></dir></style></legend>

      1. MySQL 数据透视表 - 行到列.询问

        MySQL pivot tables - rows to colums . Query(MySQL 数据透视表 - 行到列.询问)

          <bdo id='O0HWD'></bdo><ul id='O0HWD'></ul>
        • <tfoot id='O0HWD'></tfoot>
        • <legend id='O0HWD'><style id='O0HWD'><dir id='O0HWD'><q id='O0HWD'></q></dir></style></legend>

              1. <i id='O0HWD'><tr id='O0HWD'><dt id='O0HWD'><q id='O0HWD'><span id='O0HWD'><b id='O0HWD'><form id='O0HWD'><ins id='O0HWD'></ins><ul id='O0HWD'></ul><sub id='O0HWD'></sub></form><legend id='O0HWD'></legend><bdo id='O0HWD'><pre id='O0HWD'><center id='O0HWD'></center></pre></bdo></b><th id='O0HWD'></th></span></q></dt></tr></i><div id='O0HWD'><tfoot id='O0HWD'></tfoot><dl id='O0HWD'><fieldset id='O0HWD'></fieldset></dl></div>

              2. <small id='O0HWD'></small><noframes id='O0HWD'>

                  <tbody id='O0HWD'></tbody>
                  本文介绍了MySQL 数据透视表 - 行到列.询问的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我在 mysql 中有这个表:

                  I have this table in mysql:

                  <头>
                  日期姓名标记
                  2021-02-01亚历克斯7
                  2021-02-01约翰5
                  2021-02-01弗兰克4
                  2021-02-02EVA8
                  2021-02-02艾丽西亚5

                  我怎样才能得到与此类似的结果:

                  How can I get a result similar to this:

                  <头>
                  日期亚历克斯约翰弗兰克EVA艾丽西亚
                  2021-02-01754
                  2021-02-0285

                  在Mysql中可以吗?

                  It is Possible in Mysql?

                  推荐答案

                  创建过程

                  CREATE PROCEDURE pivot (tablename VARCHAR(64),
                                          groupname VARCHAR(64),
                                          pivotname VARCHAR(64),
                                          valuename VARCHAR(64))
                  BEGIN
                  SELECT CONCAT('CREATE VIEW to_columnslist AS\n',
                                'SELECT DISTINCT CONCAT(\'`\', `', pivotname,'`, \'` VARCHAR(255) path \\\'$."\', ', pivotname,', \'"\\\'\') line\n',
                                'FROM ', tablename)
                  INTO @sql;
                  PREPARE stmt FROM @sql;
                  EXECUTE stmt;
                  DROP PREPARE stmt;
                  SELECT CONCAT(
                  'SELECT to_json.`', groupname,'`, parsed.*', '\n',
                  'FROM (SELECT `', groupname,'`, JSON_OBJECTAGG(`', pivotname,'`, `', valuename,'`) json_data', '\n',
                  '      FROM `', tablename,'`', '\n',
                  '      GROUP BY `', groupname,'`) to_json', '\n',
                  'CROSS JOIN JSON_TABLE( json_data,', '\n',
                  '                       "$" COLUMNS ( ', 
                  GROUP_CONCAT(line SEPARATOR ',\n                                     '),
                  ' ) ) parsed'
                  ) sql_text
                  INTO @sql
                  FROM to_columnslist;
                  PREPARE stmt FROM @sql;
                  EXECUTE stmt;
                  DROP PREPARE stmt;
                  DROP VIEW to_columnslist;
                  END
                  

                  并使用它.

                  参见 fiddle

                  这篇关于MySQL 数据透视表 - 行到列.询问的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Bogus foreign key constraint fail(虚假外键约束失败)
                  how to get last insert id after insert query in codeigniter active record(如何在codeigniter活动记录中插入查询后获取最后一个插入ID)
                  Force InnoDB to recheck foreign keys on a table/tables?(强制 InnoDB 重新检查表/表上的外键?)
                  How to auto generate migrations with Sequelize CLI from Sequelize models?(如何使用 Sequelize CLI 从 Sequelize 模型自动生成迁移?)
                  Clear MySQL query cache without restarting server(无需重启服务器即可清除 MySQL 查询缓存)
                  ALTER TABLE to add a composite primary key(ALTER TABLE 添加复合主键)
                    • <bdo id='1TiAK'></bdo><ul id='1TiAK'></ul>

                        <small id='1TiAK'></small><noframes id='1TiAK'>

                        <i id='1TiAK'><tr id='1TiAK'><dt id='1TiAK'><q id='1TiAK'><span id='1TiAK'><b id='1TiAK'><form id='1TiAK'><ins id='1TiAK'></ins><ul id='1TiAK'></ul><sub id='1TiAK'></sub></form><legend id='1TiAK'></legend><bdo id='1TiAK'><pre id='1TiAK'><center id='1TiAK'></center></pre></bdo></b><th id='1TiAK'></th></span></q></dt></tr></i><div id='1TiAK'><tfoot id='1TiAK'></tfoot><dl id='1TiAK'><fieldset id='1TiAK'></fieldset></dl></div>
                          <tbody id='1TiAK'></tbody>
                          <legend id='1TiAK'><style id='1TiAK'><dir id='1TiAK'><q id='1TiAK'></q></dir></style></legend>
                          1. <tfoot id='1TiAK'></tfoot>