首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >本年度与去年的SQL差异。如果去年数据不存在,则包含本年度

本年度与去年的SQL差异。如果去年数据不存在,则包含本年度
EN

Stack Overflow用户
提问于 2014-05-15 16:49:22
回答 1查看 1.8K关注 0票数 0

在上一篇文章中,我得到了寻找增量销售的帮助。这个查询运行得很好。我按产品添加了分组。我遇到的问题是我需要展示正在销售的新产品。如果该产品去年不存在,但我们今年正在销售它;那么它应该显示在数据表中。

我尝试在WHERE中使用CASE语句,但它导致了大量重复数据。我的想法类似于下面的内容。如何包含仅存在于本年度的项目?谢谢你的帮助,非常感谢。

不工作Where子句

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
      WHERE
        Ym.Project = 
        CASE
            WHEN ymprev.Project IS NULL THEN ym.Project
        ELSE ymprev.Project
        END

下面是工作查询。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        WITH ym as(
                    SELECT
                        Product
                        ,SUM(Sales) AS Sales
                        ,MONTH(Date) AS Month
                        ,YEAR(Date) AS Year

                    FROM SalesTable

                    GROUP BY
                        YEAR(Date)
                        ,MONTH(Date)
                        ,Product

                    )
        SELECT
            ymprev.Project AS PrevProject
            ,ym.Product
            ,ym.Sales
            ,ymprev.Sales AS PreviousSales
            ,(ym.Sales - ymprev.Sales) AS IncrementalSales
            ,ymprev.Month AS PreviousMonth
            ,ymprev.Year AS PreviousYear
            ,ym.Month
            ,ym.Year

        FROM ym 

        JOIN ym ymprev on
            ymprev.Year = ym.Year
            AND ymprev.Month =  ym.Month
            AND ymprev.Product = ym.Product

        ORDER BY
        ym.Year
        ,ym.Month
EN

回答 1

Stack Overflow用户

发布于 2014-06-23 19:25:01

您的查询是隐式使用INNER JOIN的-这意味着您只能看到在两个数据集中有匹配的值,正如您所描述的那样。

尝试将FROM子句更改为

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
FROM ym 
 LEFT JOIN 
ym ymprev on
    ymprev.Year = ym.Year
    AND ymprev.Month =  ym.Month
    AND ymprev.Product = ym.Product

您还需要在包含前一年查询中的数据元素的任何值中包含类似的逻辑。例如,需要将,(ym.Sales - ymprev.Sales) AS IncrementalSales转换为,(ym.Sales - ISNULL(ymprev.Sales,0)) AS IncrementalSales,否则对于只存在于本年度的任何记录,它都将返回NULL。

您的posted查询没有在CTE中包含Project字段,所以我不能确切地说出它是如何工作的,但是posted的数据应该可以帮助您开始。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23684296

复制
相关文章
iOS APP添加桌面快捷方式
新接到一个需求,需要APP内的某些功能,能够把入口添加到桌面,点击桌面到入口可以直接跳转APP对应界面(类似于下面这张示例图),于是就做了一番调研。
莫空9081
2021/06/08
5.4K0
iOS APP添加桌面快捷方式
2)客户端通过OpenUrl调起Safari,再二次跳转到data url 技术实现方案是首先通过调起Safari,然后跳到一个Data URI Scheme形式下的HTML页面,而添加到主屏幕的也是这个Data URI Scheme形式下的HTML页面。 OpenUrl调起Safari的实现为: [[UIApplicationsharedApplication] openURL:[NSURL URLWithString:@"http:www.xxx.com"]]; 通过该方法即可调起Safari,让Safari访问附带的URL链接,在该功能实现中,URL链接指向一个Data URI Scheme形式下的HTML页面。如下图所示:
用户5521279
2019/06/03
7.4K3
如何向图形添加曲形文本
R语言数据分析指南
2023/08/18
2190
如何向图形添加曲形文本
如何向数组里添加元素
一般数组是不能添加元素的,因为数组在初始化时就已定好长度了,不能改变长度,我们如何做到向其中添加元素。
算法与编程之美
2023/01/03
3.5K0
kali添加桌面快捷方式
终端输入:sudo gedit /usr/share/applications/Pycharm.desktop 粘贴模板: [Desktop Entry] Type=Application Name=Pycharm GenericName=Pycharm3 Comment=Pycharm3:The Python IDE Exec=sh /opt/pycharm/bin/pycharm.sh Icon=/opt/pycharm/bin/pycharm.png Terminal=pycharm Categor
昨天50还没用完
2018/06/29
2.3K0
java如何向数组中添加元素[数组的添加]
大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说java如何向数组中添加元素[数组的添加],希望能够帮助大家进步!!!
Java架构师必看
2022/04/06
7.7K0
java如何向数组里添加元素
1、一般数组是不能添加元素的,因为他们在初始化时就已定好长度了,不能改变长度。 但有个可以改变大小的数组为ArrayList,即可以定义一个ArrayList数组,然后用add(element)方法往里添加元素即可,还可add(index,element)往指定下标处添加元素;例子如下:
全栈程序员站长
2022/06/27
20.6K0
Windows中的键盘快捷方式大全
Windows有很多键盘快捷方式,使用键盘快捷方式能够大大提高使用windows的效率,同时还能提升自己的逼格,背熟几个快捷方式,操作起来行云流水犹如大神一般!
用户7657330
2020/08/14
5.7K0
如何向已有的项目中添加C/C++代码?
  我们需要在src/main下面建立一个cpp目录,然后在其中写一个CMakeLists.txt文件和一个cpp文件,直接给出代码:
故乡的樱花开了
2023/10/22
2930
给App的应用页面注册快捷方式
元数据不单单能传递简单的字符串参数,还能传送更复杂的资源数据,从Android7.1开始新增的快捷方式便用到了这点,譬如在手机上桌面长按支付宝图标,会弹出如下图所示的菜单。
aqi00
2020/05/12
9680
Python 中如何向列表或数组添加元素
然而,与其它编程语言不同,数组在 Python 中不是一个内置的数据结构。Python 使用列表取代传统的数组。
Python学习者
2023/09/11
3600
向邮件添加附件
可以将附件添加到电子邮件或消息部分(具体地说,是添加到%Net.MailMessagePart或%Net.MailMessage的实例)。要执行此操作,请使用以下方法:
用户7741497
2022/06/09
2.1K0
如何从Windows切换到Linux
微软已经马上准备在2020年1月份终止对Windows 7的支持,这意味着您将不再获得bug修复或安全更新。如果您是Windows 7的最终支持者之一,并且不想陷入一个不安全的系统,则可以选择:升级到Windows 10或完全切换到其他版本。
用户6543014
2020/02/10
3.9K0
如何添加windows定时计划任务?
“ 我们常常使用linux添加定时任务,windows也可以吗?答案是肯定的——编程三分钟”
机智的程序员小熊
2019/12/11
1.7K0
Windows如何添加TrustedInstaller权限
权限添加,一同加的Administrator、Users、TrustedInstaller(英文分号隔开)然后点检索名称,Administrator和Users都能找到,唯独TrustedInstaller不行
Windows技术交流
2020/04/08
4.1K0
如何使用 Bootstrap class 向按钮添加下拉菜单
如何使用 Bootstrap class 向按钮添加下拉菜单。如需向按钮添加下拉菜单,只需要简单地在一个 .btn-group 容器中放置按钮和下拉菜单即可。您也可以使用 <span class="caret"></span> 来指示按钮作为下拉菜单。
好派笔记
2021/09/18
5.6K0
短视频app源码开发,如何添加启动界面
打开短视频app源码时,一般都会有一个启动界面,启动界面除了会展示APP的logo外,大多数都会将广告直接放到上面,起到引流盈利的目的。
云豹科技程序员
2021/06/21
6700
点击加载更多

相似问题

如何向windows快捷方式添加命令参数

124

如何向App添加社交功能?

43

Android:如何向App添加阴影

13

如何从azure向windows mobile cordova app发送推送通知

112

向APp添加项

12
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文