簡體   English   中英

Mysql查詢動態計算行的出現次數並將其轉換為列

[英]Mysql query to dynamically count the occurrences of a row and convert it to columns

我正在查詢mysql數據庫以總結測試執行結果。 我的數據看起來像這樣。

+-+------------+----------------+
id|test_case_id|execution_status
+-+------------+----------------+
1 |     1      |     passed
+-+------------+----------------+
2 |     2      |     failed
+-+------------+----------------+
3 |     2      |     passed
+-+------------+----------------+
4 |     1      |     passed
+-+------------+----------------+
5 |     2      |     failed
+-+------------+----------------+

如何查詢此數據以獲取此信息:

+-+------------+------+------
id|test_case_id|passed|failed
+-+------------+------+------
1 |    1       |  2   |  0
+-+------------+------+------
2 |    2       |  1   |  2
+-+------------+------+------

我能找到的最接近的東西是這個線程: Mysql查詢動態地將行轉換為列 但是,由於我需要總結執行狀態的發生,我無法讓它工作。 由於數據源和目標考慮因素,我無法使用臨時表,動態SQL或存儲過程。 任何幫助贊賞!

我認為你可以使用條件聚合。 我不知道為什么你在搜索中找不到這個:

select test_case_id, sum(execution_status = 'passed') as passed,
       sum(execution_status = 'failed') as failed
from t
group by test_case_id;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM