亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

mysql中pivot函數的用法是什么

小億
234
2024-01-26 09:15:15
欄目: 云計算

MySQL中并沒有內置的PIVOT函數,但可以使用條件聚合和CASE語句來實現類似的功能。

在MySQL中,可以使用條件聚合和CASE語句將行轉換為列。下面是一個示例,說明如何使用條件聚合和CASE語句實現PIVOT功能:

假設我們有一個名為sales的表,包含以下數據:

+-------+-------+-------+-------+
| Month | Sales | Region| Product|
+-------+-------+-------+-------+
|   1   |  100  |   A   |   X   |
|   1   |  200  |   B   |   X   |
|   2   |  150  |   A   |   Y   |
|   2   |  250  |   B   |   Y   |
+-------+-------+-------+-------+

我們想要將Region列的值作為列,并將Sales列的值作為相應的值,得到以下結果:

+-------+-------+-------+
| Month |   A   |   B   |
+-------+-------+-------+
|   1   |  100  |  200  |
|   2   |  150  |  250  |
+-------+-------+-------+

使用以下查詢可以實現此目的:

SELECT 
  Month,
  SUM(CASE WHEN Region = 'A' THEN Sales ELSE 0 END) AS A,
  SUM(CASE WHEN Region = 'B' THEN Sales ELSE 0 END) AS B
FROM sales
GROUP BY Month;

這個查詢使用了條件聚合和CASE語句:

  • 對于每個唯一的Month值,使用SUM函數將滿足條件的Sales值相加,生成新的列A和B。
  • CASE語句用于根據條件(Region的值)返回不同的結果(Sales的值或0)。

結果將根據Month進行分組,并生成新的列A和B,其中A列包含Region為’A’的Sales值,B列包含Region為’B’的Sales值。

0
赣榆县| 临猗县| 丰台区| 达拉特旗| 五原县| 平顶山市| 灵石县| 永和县| 河间市| 韶山市| 万安县| 扬中市| 济南市| 芦山县| 西乡县| 瓦房店市| 汨罗市| 平凉市| 军事| 兰西县| 滨海县| 平阳县| 建瓯市| 岱山县| 隆化县| 邢台县| 格尔木市| 巴南区| 石泉县| 高安市| 临汾市| 息烽县| 襄垣县| 东源县| 镇沅| 郧西县| 巍山| 深圳市| 乌恰县| 宿松县| 丹棱县|