AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / dba / 问题 / 143888
Accepted
Otsdarva
Otsdarva
Asked: 2016-07-15 06:48:47 +0800 CST2016-07-15 06:48:47 +0800 CST 2016-07-15 06:48:47 +0800 CST

访问:如何在查询中合并两行数据

  • 772

我有一个格式如下的基本数据集。

Sex1    | Sex2    | Number|  
F       |         | 5     |   
M       |         | 8     |
M       | F       | 5     |   
F       | F       | 3     |
M       | F       | 2     |   
F       | M       | 1     |
F       | F       | 9     |   
M       | M       | 3     |

我想使用 SQL 创建一个查询,该查询按性别组合从价格中生成总计,如下所示:

Sex | Total Number
F   |    5
M   |    8
MF  |    8 
FF  |    12
MM  |    3

但是,我正在努力寻找一种将 FM 和 MF 类别拉到同一行的方法。我拥有的使它们与众不同的代码的形式是

SELECT Sex1 & "" & Sex2 AS Sex, Sum(Number) AS [Total Number]
FROM TableName
GROUP BY Sex1 & "" & Sex2

有没有一种简单的方法来组合行?

ms-access ms-access-2010
  • 3 3 个回答
  • 3869 Views

3 个回答

  • Voted
  1. Best Answer
    ypercubeᵀᴹ
    2016-07-15T11:15:05+08:002016-07-15T11:15:05+08:00

    您可以使用CASE表达式或IIf()函数首先对两个值进行排序,然后按它们进行分组:

    用CASE表达式:

    SELECT CASE WHEN Sex1 < Sex2 THEN Sex1 ELSE Sex2 END 
           & CASE WHEN Sex1 < Sex2 THEN Sex2 ELSE Sex1 END AS Sex,
           Sum(Number) AS [Total Number]
    FROM TableName
    GROUP BY CASE WHEN Sex1 < Sex2 THEN Sex1 ELSE Sex2 END,
             CASE WHEN Sex1 < Sex2 THEN Sex2 ELSE Sex1 END ;
    

    带IIf()功能:

    SELECT IIf(Sex1 < Sex2, Sex1, Sex2) & IIf(Sex1 < Sex2, Sex2, Sex1) AS Sex,
           Sum(Number) AS [Total Number]
    FROM TableName
    GROUP BY IIf(Sex1 < Sex2, Sex1, Sex2),
             IIf(Sex1 < Sex2, Sex2, Sex1) ;
    
    • 0
  2. Gord Thompson
    2016-07-17T09:45:51+08:002016-07-17T09:45:51+08:00

    您可以使用 UNION 查询来强制 Sex1/Sex2 对的顺序相同

        SELECT 
            Nz(Sex1, "") & Nz(Sex2, "") AS Sex,
            Number
        FROM TableName
        WHERE Nz(Sex1, "") >= Nz(Sex2, "")
    UNION ALL
        SELECT 
            Nz(Sex2, "") & Nz(Sex1, "") AS Sex,
            Number
        FROM TableName
        WHERE Nz(Sex1, "") < Nz(Sex2, "")
    

    生产

    Sex  Number
    ---  ------
    FF        3
    MF        1
    FF        9
    MM        3
    F         5
    M         8
    MF        5
    MF        2
    

    然后将其用作子查询来生成总计

    SELECT
        Sex,
        SUM(Number) AS [Total Number]
    FROM
        (
                SELECT 
                    Nz(Sex1, "") & Nz(Sex2, "") AS Sex,
                    Number
                FROM TableName
                WHERE Nz(Sex1, "") >= Nz(Sex2, "")
            UNION ALL
                SELECT 
                    Nz(Sex2, "") & Nz(Sex1, "") AS Sex,
                    Number
                FROM TableName
                WHERE Nz(Sex1, "") < Nz(Sex2, "")
        )
    GROUP BY Sex
    

    生产

    Sex  Total Number
    ---  ------------
    F               5
    FF             12
    M               8
    MF              8
    MM              3
    
    • 0
  3. Priyanka Kariya
    2016-07-15T21:12:37+08:002016-07-15T21:12:37+08:00

    您可以尝试在 MSSQL 中使用 CONCAT() 函数将 2 列合二为一。

    选择 CONCAT( Sex1, Sex2) 作为 Sex,Sum( Number) 作为Total_NumberFROM db。testGROUP BY concat( Sex1, Sex2);

    • -1

相关问题

  • 从数据库中获取数据并将其放回新的数据表

  • MS Access 将 SQL Server 表中的所有列显示为“已删除”

  • 并发问题?

  • 使用参数查询在 MS Access 报告中生成图表

  • 通过 SQL Job Agent 查询网络共享上的 Linked Access 数据库

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目

    • 12 个回答
  • Marko Smith

    如何让sqlplus的输出出现在一行中?

    • 3 个回答
  • Marko Smith

    选择具有最大日期或最晚日期的日期

    • 3 个回答
  • Marko Smith

    如何列出 PostgreSQL 中的所有模式?

    • 4 个回答
  • Marko Smith

    列出指定表的所有列

    • 5 个回答
  • Marko Smith

    如何在不修改我自己的 tnsnames.ora 的情况下使用 sqlplus 连接到位于另一台主机上的 Oracle 数据库

    • 4 个回答
  • Marko Smith

    你如何mysqldump特定的表?

    • 4 个回答
  • Marko Smith

    使用 psql 列出数据库权限

    • 10 个回答
  • Marko Smith

    如何从 PostgreSQL 中的选择查询中将值插入表中?

    • 4 个回答
  • Marko Smith

    如何使用 psql 列出所有数据库和表?

    • 7 个回答
  • Martin Hope
    Jin 连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目 2014-12-02 02:54:58 +0800 CST
  • Martin Hope
    Stéphane 如何列出 PostgreSQL 中的所有模式? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh 为什么事务日志不断增长或空间不足? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland 列出指定表的所有列 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney MySQL 能否合理地对数十亿行执行查询? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx 如何监控大型 .sql 文件的导入进度? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison 你如何mysqldump特定的表? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 对 SQL 查询进行计时? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas 如何从 PostgreSQL 中的选择查询中将值插入表中? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 列出所有数据库和表? 2011-02-18 00:45:49 +0800 CST

热门标签

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve