zoukankan      html  css  js  c++  java
  • SQL Server选取本周或上一周数据

    有关SQL Server中有关周的数据查询主要思路来自下面这个语句

    select getdate(), dateadd(wk, datediff(wk, 0, DateAdd(Day,-1,getdate())), 0), dateadd(wk, datediff(wk, 0, DateAdd(Day,-1,getdate())), 0) + 6

    这是按照中国的习惯,将一周的第一天定为周一。

    依照这个为基础,就可以轻松的找到本周和上一周的数据了。

    本周示例

    Select a.* , datediff(wk, 0, DateAdd(d,-1, a.OppDate)) From (
    Select DATEADD(Day,-0,GetDate()) As OppDate Union All
    Select DATEADD(Day,-1,GetDate()) As OppDate Union All
    Select DATEADD(Day,-2,GetDate()) As OppDate Union All
    Select DATEADD(Day,-3,GetDate()) As OppDate Union All
    Select DATEADD(Day,-4,GetDate()) As OppDate Union All
    Select DATEADD(Day,-5,GetDate()) As OppDate Union All
    Select DATEADD(Day,-6,GetDate()) As OppDate Union All
    Select DATEADD(Day,-7,GetDate()) As OppDate Union All
    Select DATEADD(Day,-8,GetDate()) As OppDate Union All
    Select DATEADD(Day,-9,GetDate()) As OppDate Union All
    Select DATEADD(Day,-10,GetDate()) As OppDate Union All
    Select DATEADD(Day,-11,GetDate()) As OppDate Union All
    Select DATEADD(Day,-12,GetDate()) As OppDate Union All
    Select DATEADD(Day,-13,GetDate()) As OppDate Union All
    Select DATEADD(Day,-14,GetDate()) As OppDate Union All
    Select DATEADD(Day,-15,GetDate()) As OppDate Union All
    Select DATEADD(Day,-16,GetDate()) As OppDate Union All
    Select DATEADD(Day,-17,GetDate()) As OppDate Union All
    Select DATEADD(Day,-18,GetDate()) As OppDate Union All
    Select DATEADD(Day,-19,GetDate()) As OppDate) As a
    Where datediff(wk, 0, DateAdd(d,-1, a.OppDate)) = DATEDIFF(wk,0,DateAdd(d,-1,GetDate())) 

    上一周示例

    Select a.* , datediff(wk, 0, DateAdd(d,-1, a.OppDate)) From (
    Select DATEADD(Day,-0,GetDate()) As OppDate Union All
    Select DATEADD(Day,-1,GetDate()) As OppDate Union All
    Select DATEADD(Day,-2,GetDate()) As OppDate Union All
    Select DATEADD(Day,-3,GetDate()) As OppDate Union All
    Select DATEADD(Day,-4,GetDate()) As OppDate Union All
    Select DATEADD(Day,-5,GetDate()) As OppDate Union All
    Select DATEADD(Day,-6,GetDate()) As OppDate Union All
    Select DATEADD(Day,-7,GetDate()) As OppDate Union All
    Select DATEADD(Day,-8,GetDate()) As OppDate Union All
    Select DATEADD(Day,-9,GetDate()) As OppDate Union All
    Select DATEADD(Day,-10,GetDate()) As OppDate Union All
    Select DATEADD(Day,-11,GetDate()) As OppDate Union All
    Select DATEADD(Day,-12,GetDate()) As OppDate Union All
    Select DATEADD(Day,-13,GetDate()) As OppDate Union All
    Select DATEADD(Day,-14,GetDate()) As OppDate Union All
    Select DATEADD(Day,-15,GetDate()) As OppDate Union All
    Select DATEADD(Day,-16,GetDate()) As OppDate Union All
    Select DATEADD(Day,-17,GetDate()) As OppDate Union All
    Select DATEADD(Day,-18,GetDate()) As OppDate Union All
    Select DATEADD(Day,-19,GetDate()) As OppDate) As a
    Where datediff(wk, 0, DateAdd(d,-1, a.OppDate)) = DATEDIFF(wk,0,DateAdd(d,-1,GetDate())) - 1

  • 相关阅读:
    Flutter——限制按钮点击的时间间隔
    【友盟】添加埋点事件(以iOS和安卓端为例)
    Git——在VSCode中查看Git历史提交记录
    Flutter——【好用网站】大集合
    Flutter——数组(List)
    Flutter——实现强大的输入框功能
    基于腾讯位置服务定位实现物业巡检防作弊场景
    基于腾讯地图定位组件实现周边公用厕所远近排序分布图
    腾讯位置服务Flutter业务实践——地图SDK Flutter插件实现(一)
    微信小程序类快递自动填写收发货地址功能
  • 原文地址:https://www.cnblogs.com/songhaipeng/p/4201360.html
Copyright © 2011-2022 走看看