簡體   English   中英

如何按特定條件計算每行

[英]How to count per row by certain criteria

我有條件雇用表:

H=Hour, P=Present, S=Sick, A=Alpha

ID Name H1  H2 H3 H4 P  S   A
1  AAA   h  h  h  h  
2  BBB   s  s  h  h
3  CCC   a  h  h  h

如何得到這樣的結果:

ID Name H1  H2 H3 H4 P  S   A
1  AAA   h  h  h  h  4  0   0  
2  BBB   s  s  h  h  2  2   0
3  CCC   a  h  h  h  3  0   1

我已經瀏覽和瀏覽了 2 天,嘗試並嘗試,但我不知道如何執行 mysql 查詢來解決該問題...

預先感謝並為我的英語不好而道歉

我對您帖子中的數據做了一些假設,我認為以下查詢可能是您一直在嘗試組合的內容:

SELECT
id 'ID',
name 'Name',
h1 'H1',
h2 'H2',
h3 'H3',
h4 'H4',
SUM(if(h1='h',1,0)+if(h2='h',1,0)+if(h3='h',1,0)+if(h4='h',1,0)) as 'P',
SUM(if(h1='s',1,0)+if(h2='s',1,0)+if(h3='s',1,0)+if(h4='s',1,0)) as 'S', 
SUM(if(h1='a',1,0)+if(h2='a',1,0)+if(h3='a',1,0)+if(h4='a',1,0)) as 'A' 
FROM myTable
GROUP BY id

隨意忽略列名,因為這只是為了匹配您在帖子中放置的內容。

基本上,我們只是檢查每個字段中每列值的出現情況,如果存在則提供“1”,如果不存在則提供“0”。 然后我們將所有這些結果加在一起以產生該事件的多列計數。

然后我們GROUP BY id只計算每個 id 的行。

不過,可能有一種更優雅的方式來做到這一點。

暫無
暫無

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

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