久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

  • <legend id='gHttg'><style id='gHttg'><dir id='gHttg'><q id='gHttg'></q></dir></style></legend>
  • <i id='gHttg'><tr id='gHttg'><dt id='gHttg'><q id='gHttg'><span id='gHttg'><b id='gHttg'><form id='gHttg'><ins id='gHttg'></ins><ul id='gHttg'></ul><sub id='gHttg'></sub></form><legend id='gHttg'></legend><bdo id='gHttg'><pre id='gHttg'><center id='gHttg'></center></pre></bdo></b><th id='gHttg'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='gHttg'><tfoot id='gHttg'></tfoot><dl id='gHttg'><fieldset id='gHttg'></fieldset></dl></div>
    <tfoot id='gHttg'></tfoot>

          <bdo id='gHttg'></bdo><ul id='gHttg'></ul>

        <small id='gHttg'></small><noframes id='gHttg'>

        帶有動態列的 MySQL 數據透視表查詢

        MySQL pivot table query with dynamic columns(帶有動態列的 MySQL 數據透視表查詢)
      1. <i id='zaBrr'><tr id='zaBrr'><dt id='zaBrr'><q id='zaBrr'><span id='zaBrr'><b id='zaBrr'><form id='zaBrr'><ins id='zaBrr'></ins><ul id='zaBrr'></ul><sub id='zaBrr'></sub></form><legend id='zaBrr'></legend><bdo id='zaBrr'><pre id='zaBrr'><center id='zaBrr'></center></pre></bdo></b><th id='zaBrr'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='zaBrr'><tfoot id='zaBrr'></tfoot><dl id='zaBrr'><fieldset id='zaBrr'></fieldset></dl></div>
          <tbody id='zaBrr'></tbody>

        <tfoot id='zaBrr'></tfoot>

                <small id='zaBrr'></small><noframes id='zaBrr'>

              • <legend id='zaBrr'><style id='zaBrr'><dir id='zaBrr'><q id='zaBrr'></q></dir></style></legend>
                • <bdo id='zaBrr'></bdo><ul id='zaBrr'></ul>
                  本文介紹了帶有動態列的 MySQL 數據透視表查詢的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

                  問題描述

                  我使用下表來存儲產品數據:

                  I'm using the following tables for storing product data:

                  mysql> SELECT * FROM product;
                  +---------------+---------------+--------+
                  | id | name     | description   | stock  |
                  +---------------+---------------+--------+
                  |  1 | product1 | first product |    5   | 
                  |  2 | product2 | second product|    5   | 
                  +---------------+---------------+--------+
                  
                  mysql> SELECT * FROM product_additional;
                  +-----------------+------------+
                  | id | fieldname  | fieldvalue |
                  +-----------------+------------+
                  |  1 | size       | S          |
                  |  1 | height     | 103        |
                  |  2 | size       | L          |
                  |  2 | height     | 13         |
                  |  2 | color      | black      |
                  +-----------------+------------+
                  

                  使用以下查詢從兩個表中選擇記錄

                  Using the following query to select the records from both tables

                  mysql> SELECT 
                      p.id
                      , p.name
                      , p.description
                      ,MAX(IF(pa.fieldname = 'size', pa.fieldvalue, NULL)) as `size`
                      ,MAX(IF(pa.fieldname = 'height', pa.fieldvalue, NULL)) as `height`
                      ,MAX(IF(pa.fieldname = 'color', pa.fieldvalue, NULL)) as `color`
                  FROM product p
                  LEFT JOIN product_additional AS pa ON p.id = pa.id
                  GROUP BY p.id
                  +---------------+---------------+--------+---------+--------+
                  | id | name     | description   | size   | height  | color  |
                  +---------------+---------------+--------+---------+--------+
                  |  1 | product1 | first product | S      | 103     | null   |
                  |  2 | product2 | second product| L      | 13      | black  |
                  +---------------+---------------+--------+---------+--------+
                  

                  而且一切正常:)

                  因為我動態填充附加"表,如果查詢也是動態的,那就太好了.這樣我就不必每次輸入新的字段名和字段值時都更改查詢.

                  Because i fill the 'additional' table dynamically it would be nice, if the query would also be dynamic. In that way i dont have to change the query everytime i put in a new fieldname and fieldvalue.

                  推薦答案

                  在 MySQL 中動態執行此操作的唯一方法是使用 Prepared 語句.這是一篇關于它們的好文章:

                  The only way in MySQL to do this dynamically is with Prepared statements. Here is a good article about them:

                  動態數據透視表(將行轉換為列)

                  您的代碼如下所示:

                  SET @sql = NULL;
                  SELECT
                    GROUP_CONCAT(DISTINCT
                      CONCAT(
                        'MAX(IF(pa.fieldname = ''',
                        fieldname,
                        ''', pa.fieldvalue, NULL)) AS ',
                        fieldname
                      )
                    ) INTO @sql
                  FROM product_additional;
                  
                  SET @sql = CONCAT('SELECT p.id
                                      , p.name
                                      , p.description, ', @sql, ' 
                                     FROM product p
                                     LEFT JOIN product_additional AS pa 
                                      ON p.id = pa.id
                                     GROUP BY p.id, p.name, p.description');
                  
                  PREPARE stmt FROM @sql;
                  EXECUTE stmt;
                  DEALLOCATE PREPARE stmt;
                  

                  參見演示

                  注意:GROUP_CONCAT 函數有 1024 個字符的限制.參見參數 group_concat_max_len

                  NOTE: GROUP_CONCAT function has a limit of 1024 characters. See parameter group_concat_max_len

                  這篇關于帶有動態列的 MySQL 數據透視表查詢的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

                  【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

                  相關文檔推薦

                  How to use windowing functions efficiently to decide next N number of rows based on N number of previous values(如何有效地使用窗口函數根據 N 個先前值來決定接下來的 N 個行)
                  reuse the result of a select expression in the quot;GROUP BYquot; clause?(在“GROUP BY中重用選擇表達式的結果;條款?)
                  Does ignore option of Pyspark DataFrameWriter jdbc function ignore entire transaction or just offending rows?(Pyspark DataFrameWriter jdbc 函數的 ignore 選項是忽略整個事務還是只是有問題的行?) - IT屋-程序員軟件開發技
                  Error while using INSERT INTO table ON DUPLICATE KEY, using a for loop array(使用 INSERT INTO table ON DUPLICATE KEY 時出錯,使用 for 循環數組)
                  pyspark mysql jdbc load An error occurred while calling o23.load No suitable driver(pyspark mysql jdbc load 調用 o23.load 時發生錯誤 沒有合適的驅動程序)
                  How to integrate Apache Spark with MySQL for reading database tables as a spark dataframe?(如何將 Apache Spark 與 MySQL 集成以將數據庫表作為 Spark 數據幀讀取?)

                      <tbody id='ZH27a'></tbody>
                    <tfoot id='ZH27a'></tfoot><legend id='ZH27a'><style id='ZH27a'><dir id='ZH27a'><q id='ZH27a'></q></dir></style></legend>
                    • <small id='ZH27a'></small><noframes id='ZH27a'>

                          <bdo id='ZH27a'></bdo><ul id='ZH27a'></ul>
                        • <i id='ZH27a'><tr id='ZH27a'><dt id='ZH27a'><q id='ZH27a'><span id='ZH27a'><b id='ZH27a'><form id='ZH27a'><ins id='ZH27a'></ins><ul id='ZH27a'></ul><sub id='ZH27a'></sub></form><legend id='ZH27a'></legend><bdo id='ZH27a'><pre id='ZH27a'><center id='ZH27a'></center></pre></bdo></b><th id='ZH27a'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='ZH27a'><tfoot id='ZH27a'></tfoot><dl id='ZH27a'><fieldset id='ZH27a'></fieldset></dl></div>

                            主站蜘蛛池模板: 国产精品久久久久久久久大全 | a免费视频 | heyzo在线| 精品久久久一区 | 一区二区三区视频在线观看 | 免费av电影网站 | 成人免费在线 | a级毛片毛片免费观看久潮喷 | 精品视频网 | 久久久tv| 日韩中文字幕高清 | 麻豆av免费观看 | 日本精品在线一区 | 久久99精品久久久久 | 欧美专区在线 | 精品一区二区在线观看 | 91亚洲精品久久久电影 | 久久久网 | 色婷婷综合久久久中字幕精品久久 | 国产免费福利小视频 | 久久久久成人精品 | 五月综合激情婷婷 | 国产一区二区日韩 | 日韩欧美中文字幕在线观看 | 99爱免费 | 亚洲成人在线免费 | 亚洲国产欧美91 | 毛片av免费在线观看 | 玖玖精品视频 | 99精品一区二区三区 | 天天躁日日躁狠狠的躁天龙影院 | 亚洲专区在线 | 在线激情视频 | 亚洲国产精品久久久久婷婷老年 | 欧美一区久久 | 九九热这里只有精品在线观看 | 亚洲一区二区久久 | h在线看 | 免费毛片网站 | 国产乱一区二区三区视频 | 一区二区三区日 |