MySQL 按行分组

标签 mysql sql group-by pivot-table summarization

我有一个如下所示的表格:

<小时/>
Associate Pay_Code Hours    Site    Date       Week     Year
Bill    REG  8.0    US  3/3/2014    10      2014
Bill    REG  8.0    US  3/4/2014    10      2014
Bill    REG  8.0    US  3/5/2014    10      2014
Bill    REG  8.0    US  3/6/2014    10      2014
Bill    VTO  6.0    US  3/7/2014    10      2014
Bill    PERS 2.0    US  3/7/2014    10      2014
Mary    REG  8.0    Canada  3/3/2014    10      2014
Mary    REG  8.0    Canada  3/4/2014    10      2014
Mary    REG  8.0    Canada  3/5/2014    10      2014
Mary    REG  8.0    Canada  3/6/2014    10      2014
Mary    REG  6.0    Canada  3/7/2014    10      2014
Mary    PERS 2.0    Canada  3/7/2014    10      2014
Fred    REG  8.0    England 3/3/2014    10      2014
Fred    REG  8.0    England 3/4/2014    10      2014
Fred    REG  8.0    England 3/5/2014    10      2014
Fred    REG  8.0    England 3/6/2014    10      2014
Fred    REG  8.0    England 3/7/2014    10      2014
Wilma   REG  8.0    Jamaica 3/3/2014    10      2014
Wilma   REG  8.0    Jamaica 3/4/2014    10      2014
Wilma   REG  8.0    Jamaica 3/5/2014    10      2014
Wilma   REG  8.0    Jamaica 3/6/2014    10      2014
Wilma   REG  8.0    Jamaica 3/7/2014    10      2014
Wilma   OT   5.0    Jamaica 3/7/2014    10      2014
Jethro  REG  8.0    Africa  3/3/2014    10      2014
Jethro  REG  8.0    Africa  3/4/2014    10      2014
Jethro  REG  8.0    Africa  3/5/2014    10      2014
Jethro  REG  8.0    Africa  3/6/2014    10      2014
Jethro  REG  8.0    Africa  3/7/2014    10      2014
Jethro  OT   8.0    Africa  3/7/2014    10      2014
Frank   REG  8.0    Iraq    3/3/2014    10      2014
Frank   PERS 8.0    Iraq    3/4/2014    10      2014
Frank   PERS 8.0    Iraq    3/5/2014    10      2014
Frank   VACP 8.0    Iraq    3/6/2014    10      2014
Frank   VACP 8.0    Iraq    3/7/2014    10      2014
<小时/>

此查询:

SELECT Pay_Code, Site, SUM(Hours), Week(Date,4), YEAR(Date)

FROM table

GROUP BY Pay_Code, Site, YEAR(Date), WEEK(Date,4)

给我:

Pay Code    Site    Sum of Hours     Week     Year
OT          Africa   8.0             10      2014 
            Jamaica  5.0             10      2014 
PERS        Canada   2.0             10      2014 
            Iraq     16.0             10      2014 
            US       2.0             10      2014 
REG         Africa   40.0             10      2014 
            Canada   38.0             10      2014 
            England  40.0             10      2014 
            Iraq     8.0             10      2014 
            Jamaica  40.0             10      2014 
            US       32.0             10      2014 
VACP        Iraq     16.0             10      2014 
VTO         US       6.0             10      2014 

我想做的是将 Pay_Code 组分组,以便可以进一步总结它们。看起来像这样的东西:

Pay Code2           Pay Code    Site    Sum of Hours      Week     Year
OT                  OT          Africa   8.0              10      2014
                                Jamaica  5.0              10      2014
Paid Shrink         PERS        Canada   2.0              10      2014
                                Iraq     16.0             10      2014
                                US       2.0              10      2014
                    VACP        Iraq     16.0              10      2014
REG                 REG         Africa   40.0              10      2014
                                Canada   38.0              10      2014
                                England  40.0              10      2014
                                Iraq     8.0              10      2014
                                Jamaica  40.0              10      2014
                                US       32.0              10      2014
Unpaid Shrink       VTO             US       6.0             10      2014

目标是按站点、按周报告 Pay_Code2 字段,但表中不存在 Pay_Code2 字段。现在,我查询大量数据并使用数据透视表对我的行进行分组。如果可能的话,我想在 MySQL 中执行此操作。

最佳答案

听起来您正在尝试根据 PayCode 值创建一个新类别。你可以尝试这样的事情:

SELECT CASE
         WHEN Pay_Code = 'OT' THEN 'OT'
         WHEN Pay_Code IN ('VACP','PERS') THEN 'Paid Shrink'
         WHEN Pay_Code = 'REG' THEN 'REG'
         WHEN Pay_Code IN ('VTO','LOA','BER') THEN 'Unpaid Shrink'
         ELSE 'Unknown'
       END as PayCode_2
       ,YEAR(Date), WEEK(Date,4), SUM(Hours), Site, Pay_Code
FROM table
GROUP BY PayCode_2, Pay_Code, Site, YEAR(Date), WEEK(Date,4)

关于MySQL 按行分组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22147117/

相关文章:

group-by - 如何在 ionic 2 中按月对项目进行分组?

mysql - 选择包含航行补丁更改日期的唯一记录

mysql - 索引未显示为可能的键

mysql - 如何在 MySQL : set website to www. website.com/"partnumber"中更新

c# - `WHERE … IN @xs` ,其中 @xs 参数是一个值列表 : Supported by ADO. NET?

sql - postgresql 连接查询

mysql - SQL 查询建议每个用户的下一个测验

mysql - 如何设计电影数据库?

mysql - tomcat 应用程序中的 Wait_timeout

mysql - 在 mySQL 中使用 MAX() 函数时获取正确的详细信息