关于sql中日期相关跨年处理

简介:

 

关于sql数据库里日期的跨年处理:


读取本周和上周纪录时,涉及跨年数据要特殊处理:


数据库里周数保存 1-52周。


按照sql函数取得周数时会出现53的问题。


写入数据库时要处理州周为53的情况,

week=53   则当作下1年处理

nian=nian+1
week=1

 

本周:

 SET DATEFIRST 1 -- 设置周一为一周的第一天
 declare @week_year int
 set @week_year = year(getdate())
 declare @week smallint -- 第几周
 select @week = datepart(week,getdate())
 
 if(@week=53)
 begin
  set @week_year=@week_year+1
  set @week=1
 end


上周:


 SET DATEFIRST 1 -- 设置周一为一周的第一天

 declare @last_week_year int

 set @last_week_year = year(getdate())

 declare @last_week smallint -- 第几周

 select @last_week = datepart(week,getdate())
 
 if(@last_week=1)
  begin
   set @last_week_year=@last_week_year-1
   set @last_week=52
  end
 else
  begin
   set @last_week=@last_week-1
  end


上上周:


 SET DATEFIRST 1 -- 设置周一为一周的第一天

 declare @last_last_week_year int

 set @last_last_week_year = year(getdate())

 declare @last_last_week smallint -- 第几周

 select @last_last_week = datepart(week,getdate())
 
 if(@last_last_week=1)
  begin
   set @last_last_week_year=@last_last_week_year-1
   set @last_last_week=51
  end
 else if(@last_last_week=2)
  begin
   set @last_last_week_year=@last_last_week_year-1
   set @last_last_week=52
  end
 else
  begin
   set @last_last_week=@last_last_week-2
  end

 

 

本月:


 declare @today_year int
 declare @today_month int


 set @today_year = year(getdate())
 set @today_month = month(getdate())

 

 

上月:

 

 declare @last_month_year int
 declare @last_month int
 set @last_month_year = year(getdate())
 set @last_month = month(getdate())
 
 if (@last_month = 1)
  begin
    set @last_month = 12
    set @last_month_year =@last_month_year -1
  end 
 else if (@last_month != 1)
  begin
   set @last_month = @last_month-1
  end
 

目录
相关文章
|
SQL BI 数据库
达梦(DM) SQL日期操作及分析函数
讲述DM 数据库中如何实现各种日期相关的运算以及如何利用分析函数 lead() over() 进行范围问题的处理
|
SQL Serverless 数据库
|
2月前
|
SQL 开发框架 .NET
sql server日期时间函数
sql server日期时间函数
42 2
|
2月前
|
SQL 关系型数据库 MySQL
SQL日期函数
SQL日期函数
|
4月前
|
Java 应用服务中间件 Maven
从零到英雄:一步步构建你的首个 JSF 应用程序,揭开 JavaServer Faces 的神秘面纱
【8月更文挑战第31天】JavaServer Faces (JSF) 是一种强大的 Java EE 标准,用于构建企业级 Web 应用。它提供了丰富的组件库和声明式页面描述语言 Facelets,便于开发者快速开发功能完善且易于维护的 Web 应用。本文将指导你从零开始构建一个简单的 JSF 应用,包括环境搭建、依赖配置、Managed Bean 编写及 Facelets 页面设计。
100 0
|
4月前
|
SQL 关系型数据库 MySQL
【超全整理】SQL日期与时间函数大汇总会:MySQL与SQL Server双轨对比教学,助你轻松搞定时间数据处理难题!
【8月更文挑战第31天】本文介绍了在不同SQL数据库系统(如MySQL、SQL Server、Oracle)中常用的日期与时间函数,包括DATE、NOW()、EXTRACT()、DATE_ADD()、TIMESTAMPDIFF()及日期格式化等,并提供了具体示例。通过对比这些函数在各系统中的使用方法,帮助开发者更高效地处理日期时间数据,满足多种应用场景需求。
452 0
|
5月前
|
SQL 数据处理
SQL 能力问题之合并两个存在交叉的日期区间,如何解决
SQL 能力问题之合并两个存在交叉的日期区间,如何解决
|
7月前
|
SQL HIVE
【Hive SQL 每日一题】统计用户连续下单的日期区间
该SQL代码用于统计用户连续下单的日期区间。首先按`user_id`和`order_date`分组并去除重复,然后使用`row_number()`标记行号,并通过`date_sub`与行号计算潜在的连续日期。接着按用户ID和计算后的日期分组,排除连续订单数少于2的情况,最后提取连续下单的起始和结束日期。输出结果展示了用户连续下单的日期范围。
239 0
|
7月前
|
SQL 索引
SQL日期函数
SQL日期函数
65 0
|
7月前
|
SQL 关系型数据库 MySQL
sql查询指定日期前n天数据
sql查询指定日期前n天数据