---------------一个常见的项目中的问题(SQL SERVER和DB2)-------------

2023-05-16

相信大家都应该会碰见这样的问题。

求全年12月每个月每个单位的统计数量,为空的需要补全。也许表述得不是很清楚,下面把我的代码贴在这里就知道是怎么回事了

SELECT 
  B.UNITCODE,B.月份,ISNULL(A.上旬,0) AS 上旬,ISNULL(A.中旬,0) AS 中旬,ISNULL(A.下旬,0) AS 下旬
FROM 
(
SELECT 
  UNITCODE,
  MONTH(OPDATE) AS 月份,
  SUM(CASE WHEN DAY(OPDATE)<=10 THEN 1 ELSE 0 END) AS 上旬,
  SUM(CASE WHEN DAY(OPDATE)>10 AND DAY(OPDATE)<=20 THEN 1 ELSE 0 END) AS 中旬,
  SUM(CASE WHEN DAY(OPDATE)>20 THEN 1 ELSE 0 END) AS 下旬
FROM
  FLIGHT
GROUP BY
  UNITCODE,MONTH(OPDATE)
) A
RIGHT JOIN
(
SELECT * FROM 
(
SELECT DISTINCT UNITCODE FROM FLIGHT
) AS A
CROSS JOIN 
(
SELECT NUMBER AS 月份 FROM MASTER..SPT_VALUES WHERE NUMBER BETWEEN 1 AND 12 AND TYPE='P'
)B
) AS B
ON
  A.UNITCODE=B.UNITCODE AND A.月份=B.月份
ORDER BY
  B.UNITCODE,B.月份



DB2的解决办法:

SELECT 
  B.UNITCODE,B.月份,NVL(A.上旬,0) AS 上旬,NVL(A.中旬,0) AS 中旬,NVL(A.下旬,0) AS 下旬
FROM 
(
SELECT 
  UNITCODE,
  MONTH(OPDATE) AS 月份,
  SUM(CASE WHEN DAY(OPDATE)<=10 THEN 1 ELSE 0 END) AS 上旬,
  SUM(CASE WHEN DAY(OPDATE)>10 AND DAY(OPDATE)<=20 THEN 1 ELSE 0 END) AS 中旬,
  SUM(CASE WHEN DAY(OPDATE)>20 THEN 1 ELSE 0 END) AS 下旬
FROM
  FLIGHT
GROUP BY
  UNITCODE,MONTH(OPDATE)
) A
RIGHT JOIN
(
SELECT * FROM 
(
SELECT DISTINCT UNITCODE FROM FLIGHT
) AS A
CROSS JOIN 
(
SELECT ROW_NUMBER()OVER(ORDER BY (VALUES 1)) AS 月份 FROM SYSIBM.SYSCOLUMNS FETCH FIRST 12 ROWS ONLY
)B
) AS B
ON
  A.UNITCODE=B.UNITCODE AND A.月份=B.月份
ORDER BY
  B.UNITCODE,B.月份



很简单的代码,但是比较实用,就交给初学者看看吧。



本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

---------------一个常见的项目中的问题(SQL SERVER和DB2)------------- 的相关文章

  • POINT 列上的 MySQL INSERT/UPDATE

    我正在尝试用我国家的地理位置填充我的数据库 我的一张表有 4 个字段 ID PK 纬度 经度和地理点 EDIT SCDBs Punto Geografico SET lat 18 469692 SET lon 63 93212 SET g
  • 优化 SQL Server 上的删除

    Deletesql server 上的有时很慢 我经常需要优化它们以减少所需的时间 我一直在谷歌上搜索一些关于如何做到这一点的提示 并且我发现了各种各样的建议 我想知道你最喜欢和最有效的驯服删除野兽的技术 以及它们如何以及为什么起作用 到目
  • java ResultSet,使用MAX sql函数

    你好 这就是我想要的 我连接到数据库并检索 UniqueId 列的最大元素 并将其分配给名为 maxID 的整数变量 这是我的方法 int maxID 0 Statement s2 con createStatement s2 execut
  • PL/pgSQL SELECT 到数组中

    这是我的函数声明和主体的一部分 CREATE OR REPLACE FUNCTION access update RETURNS void AS DECLARE team ids bigint BEGIN SELECT INTO team
  • 插入 Hive 表 - 非分区表到具有多个分区的分区表 - 无法插入目标表,因为列号/类型

    当我尝试插入分区表时 出现以下错误 SemanticException 错误 10044 第 1 23 行无法插入目标表 因为列号 类型不同 表 insclause 0 有 6 列 这 3 列已分区 我们不需要任何必须从中转储 存储的过滤器
  • 串行类型的外键 - 确保始终手动填充

    我有两个表 国家和地区 CREATE TABLE Countries id SERIAL name VARCHAR 40 NOT NULL PRIMARY KEY id CREATE TABLE Regions id SERIAL coun
  • 只获取倒数第二条记录 - mysql-query

    我有一个如下表记录 my table id rating description 1 0 0 bed 2 1 0 good 3 0 0 bed 4 1 0 good 5 0 0 bed 6 0 0 bed 7 0 0 bed 现在我通过评级
  • 根据日期顺序排名

    我的数据如下 Heading Date A 2009 02 01 B 2009 02 03 c 2009 02 05 d 2009 02 06 e 2009 02 08 我需要如下排名 Heading Date Rank A 2009 02
  • MySQL中如何声明变量?

    如何在mysql中声明一个变量 以便我的第二个查询可以使用它 我想写一些类似的东西 SET start 1 SET finish 10 SELECT FROM places WHERE place BETWEEN start AND fin
  • 在存储过程中验证用户的最简单方法?

    我需要一个存储过程 可以通过发送以下内容来检查登录尝试时他们是否是有效用户login and password查看它们在数据库中是否匹配 有没有一种简单的方法可以做到这一点 如果没有更多信息 我目前能提供的最好信息是 CREATE STOR
  • SQL Server 连接其他表中不存在的位置

    Service Asset AssetService Id Name Id Name AssetId ServiceId
  • 如何识别拼写不同的相似单词

    我想从数据库中过滤掉重复的客户名称 一位客户可能有多个同名但拼写差异不大的系统条目 这是一个示例 名为 Brook 的客户可能有 3 个系统条目 有了这个变化 布鲁克 贝尔塔 布鲁克 贝尔塔 比鲁克 贝尔塔 假设我们将此名称放入一个数据库列
  • 如何在 DB2 中创建返回序列值的函数?

    如何在 DB2 中创建一个从序列中获取值并返回该值的函数 应该可以在 select 或 insert 语句中使用该函数 例如 select my func from xxx insert into xxx values my func 基本
  • 解析带下划线的 SQL Server 数字文字

    我想知道它为什么有效以及为什么它不返回错误 SELECT 2015 11 Result 11 2015 第二种情况 SELECT 2 1 a a 2 1 检查元数据 SELECT name system type name FROM sys
  • 从 Getdate() 获取时间

    我想采取Getdate 结果 例如 2011 10 05 11 26 55 000 into 11 26 55 AM 我看过其他地方并发现 Select RIGHT CONVERT VARCHAR GETDATE 100 7 这给了我 11
  • SQL查询查找表的主键?

    我怎样才能找到哪一列首要的关键使用查询来创建表 这是重复的question https stackoverflow com questions 893874 mysql determine tables primary key dynami
  • Spring 3 匹配通配符严格,但找不到元素 'jee:jndi-lookup' 的声明

    所以我遇到了与这里类似的问题 Spring 3 0错误 匹配通配符严格 但找不到元素的声明 https stackoverflow com questions 8651781 spring 3 0 error the matching wi
  • Spark SQL 中的 SQL LIKE

    我正在尝试使用 LIKE 条件在 Spark SQL 中实现联接 我正在执行连接的行看起来像这样 称为 修订 Table A 8NXDPVAE Table B 4 8 NXD V 在 SQL Server 上执行联接 A revision
  • 快速将列的副本添加到 MySQL 表

    我需要一种快速的方法来复制表中的 DATETIME 列并为其指定一个新名称 我的表中有一个名为 myDate 的列 名为 myResults 我需要一个查询来在名为 newDate 的表中创建一个新列 该列的数据与 myDate 列完全相同
  • 如何获取自定义订单的结果? [关闭]

    Closed 这个问题需要细节或清晰度 help closed questions 目前不接受答案 代替ASC or DESC 我希望我的查询结果采用特定的自定义顺序 例如 如果我想要的结果不是 A B C D 而是 P A L H 该怎么

随机推荐