`

按月 周 季度查询等日期处理的SQL语句大全

    博客分类:
  • sql
阅读更多

这篇文章共分三个部分,收集了在互联网上用来处理MSSQL日期时间的几种方法。这里按我收集的先后排列。

第一部分:SQL的本月统计和本周统计
本月统计(MySQL)
select * from booking where month(booking_time) = month(curdate()) and year(booking_time) = year(curdate())

本周统计(MySQL)
select * from spf_booking where month(booking_time) = month(curdate()) and week(booking_time) = week(curdate())


[SQLServer]
表名为:tableName
时间字段名为:theDate

查询本月的记录
select * from tableName where DATEPART(mm, theDate) = DATEPART(mm, GETDATE()) and DATEPART(yy, theDate) = DATEPART(yy, GETDATE())

查询本周的记录
select * from tableName where DATEPART(wk, theDate) = DATEPART(wk, GETDATE()) and DATEPART(yy, theDate) = DATEPART(yy, GETDATE())

查询本季的记录
select * from tableName where DATEPART(qq, theDate) = DATEPART(qq, GETDATE()) and DATEPART(yy, theDate) = DATEPART(yy, GETDATE())



select datediff(day,
dateadd(mm, datediff(mm,'''',getdate()), ''''),
dateadd(mm, datediff(mm,'''',getdate()), ''1900-02-01''))

选择本月信息

Select *
FROM [表名]
Where (DATEPART(mm, 日期) = @month) AND (DATEPART(yy, 日期) = @year)

参考资料:

1、http://twtpl368.bokee.com/viewdiary.11124860.html
2、http://hi.baidu.com/zjcxy/blog/item/5d4de5fc25721efefd037f44.html

第二部分:SQL日期格式化应用大全

Sql Server 中一个非常强大的日期格式化函数
Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AM
Select CONVERT(varchar(100), GETDATE(), 1): 05/16/06
Select CONVERT(varchar(100), GETDATE(), 2): 06.05.16
Select CONVERT(varchar(100), GETDATE(), 3): 16/05/06
Select CONVERT(varchar(100), GETDATE(), 4): 16.05.06
Select CONVERT(varchar(100), GETDATE(), 5): 16-05-06
Select CONVERT(varchar(100), GETDATE(), 6): 16 05 06
Select CONVERT(varchar(100), GETDATE(), 7): 05 16, 06
Select CONVERT(varchar(100), GETDATE(), 8): 10:57:46
Select CONVERT(varchar(100), GETDATE(), 9): 05 16 2006 10:57:46:827AM
Select CONVERT(varchar(100), GETDATE(), 10): 05-16-06
Select CONVERT(varchar(100), GETDATE(), 11): 06/05/16
Select CONVERT(varchar(100), GETDATE(), 12): 060516
Select CONVERT(varchar(100), GETDATE(),

13): 16 05 2006 10:57:46:937
Select CONVERT(varchar(100), GETDATE(), 14): 10:57:46:967
Select CONVERT(varchar(100), GETDATE(), 20): 2006-05-16 10:57:47
Select CONVERT(varchar(100), GETDATE(), 21): 2006-05-16 10:57:47.157
Select CONVERT(varchar(100), GETDATE(), 22): 05/16/06 10:57:47 AM
Select CONVERT(varchar(100), GETDATE(), 23): 2006-05-16
Select CONVERT(varchar(100), GETDATE(), 24): 10:57:47
Select CONVERT(varchar(100), GETDATE(), 25): 2006-05-16 10:57:47.250
Select CONVERT(varchar(100), GETDATE(), 100): 05 16 2006 10:57AM
Select CONVERT(varchar(100), GETDATE(), 101): 05/16/2006
Select CONVERT(varchar(100), GETDATE(), 102): 2006.05.16
Select CONVERT(varchar(100), GETDATE(), 103): 16/05/2006
Select CONVERT(varchar(100), GETDATE(), 104): 16.05.2006
Select CONVERT(varchar(100), GETDATE(), 105): 16-05-2006
Select CONVERT(varchar(100), GETDATE(), 106): 16 05 2006
Select CONVERT(varchar(100), GETDATE(), 107): 05 16, 2006
Select CONVERT(varchar(100), GETDATE(), 108): 10:57:49
Select CONVERT(varchar(100), GETDATE(), 109): 05 16 2006 10:57:49:437AM
Select CONVERT(varchar(100), GETDATE(), 110): 05-16-2006
Select CONVERT(varchar(100), GETDATE(), 111): 2006/05/16
Select CONVERT(varchar(100), GETDATE(), 112): 20060516
Select CONVERT(varchar(100), GETDATE(), 113): 16 05 2006 10:57:49:513
Select CONVERT(varchar(100), GETDATE(), 114): 10:57:49:547
Select CONVERT(varchar(100), GETDATE(), 120): 2006-05-16 10:57:49
Select CONVERT(varchar(100), GETDATE(), 121): 2006-05-16 10:57:49.700
Select CONVERT(varchar(100), GETDATE(), 126): 2006-05-16T10:57:49.827
Select CONVERT(varchar(100), GETDATE(), 130): 18 ???? ?????? 1427 10:57:49:907AM
Select CONVERT(varchar(100), GETDATE(), 131): 18/04/1427 10:57:49:920AM


常用:
Select CONVERT(varchar(100), GETDATE(), 8): 10:57:46
Select CONVERT(varchar(100), GETDATE(), 24): 10:57:47
Select CONVERT(varchar(100), GETDATE(), 108): 10:57:49
Select CONVERT(varchar(100), GETDATE(), 12): 060516
Select CONVERT(varchar(100), GETDATE(), 23): 2006-05-16

参考资料:
http://www.webwoo.net/bc/bencandy-26-14479-1.htm

第三部分:SQL Server各种日期计算方法

SQL Server各种日期计算方法
出处:CSDN.NET[ 2005-02-22 10:12:52 ]  作者:xpilot  责任编辑:lujiezhen

   通常,你需要获得当前日期和计算一些其他的日期,例如,你的程序可能需要判断一个月的第一天或者最后一天。你们大部分人大概都知道怎样把日期进行分割 (年、月、日等),然后仅仅用分割出来的年、月、日等放在几个函数中计算出自己所需要的日期!在这篇文章里,我将告诉你如何使用DATEADD和 DATEDIFF函数来计算出在你的程序中可能你要用到的一些不同日期。
被过滤广告


  在使用本文中的例子之前,你必 须注意以下的问题。大部分可能不是所有例子在不同的机器上执行的结果可能不一样,这完全由哪一天是一个星期的第一天这个设置决定。第一天 (DATEFIRST)设定决定了你的系统使用哪一天作为一周的第一天。所有以下的例子都是以星期天作为一周的第一天来建立,也就是第一天设置为7。假如 你的第一天设置不一样,你可能需要调整这些例子,使它和不同的第一天设置相符合。你可以通过@@DATEFIRST函数来检查第一天设置。
  
   为了理解这些例子,我们先复习一下DATEDIFF和DATEADD函数。DATEDIFF函数计算两个日期之间的小时、天、周、月、年等时间间隔总 数。DATEADD函数计算一个日期通过给时间间隔加减来获得一个新的日期。要了解更多的DATEDIFF和DATEADD函数以及时间间隔可以阅读微软 联机帮助。
  
  使用DATEDIFF和DATEADD函数来计算日期,和本来从当前日期转换到你需要的日期的考虑方法有点不同。你 必须从时间间隔这个方面来考虑。比如,从当前日期到你要得到的日期之间有多少时间间隔,或者,从今天到某一天(比如1900-1-1)之间有多少时间间 隔,等等。理解怎样着眼于时间间隔有助于你轻松的理解我的不同的日期计算例子。
  
  一个月的第一天
  
  第一个例子,我将告诉你如何从当前日期去这个月的最后一天。请注意:这个例子以及这篇文章中的其他例子都将只使用DATEDIFF和DATEADD函数来计算我们想要的日期。每一个例子都将通过计算但前的时间间隔,然后进行加减来得到想要计算的日期。
  
  这是计算一个月第一天的SQL 脚本:
  Select DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)
  
   我们把这个语句分开来看看它是如何工作的。最核心的函数是getdate(),大部分人都知道这个是返回当前的日期和时间的函数。下一个执行的函数 DATEDIFF(mm,0,getdate())是计算当前日期和“1900-01-01 00:00:00.000”这个日期之间的月数。记住:时期和时间变量和毫秒一样是从“1900-01-01 00:00:00.000”开始计算的。这就是为什么你可以在DATEDIFF函数中指定第一个时间表达式为“0”。下一个函数是DATEADD,增加当 前日期到“1900-01-01”的月数。通过增加预定义的日期“1900-01-01”和当前日期的月数,我们可以获得这个月的第一天。另外,计算出来 的日期的时间部分将会是“00:00:00.000”。
  
  这个计算的技巧是先计算当前日期到“1900-01-01”的时间间隔数,然后把它加到“1900-01-01”上来获得特殊的日期,这个技巧可以用来计算很多不同的日期。下一个例子也是用这个技巧从当前日期来产生不同的日期。

  本周的星期一
  
  这里我是用周(wk)的时间间隔来计算哪一天是本周的星期一。
  
  Select DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)
  
  一年的第一天
  
  现在用年(yy)的时间间隔来显示这一年的第一天。
  
  Select DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)
  
  季度的第一天
  
  假如你要计算这个季度的第一天,这个例子告诉你该如何做。
  
  Select DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)
  
  当天的半夜
  
  曾经需要通过getdate()函数为了返回时间值截掉时间部分,就会考虑到当前日期是不是在半夜。假如这样,这个例子使用DATEDIFF和DATEADD函数来获得半夜的时间点。
  
  Select DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)
  
  深入DATEDIFF和DATEADD函数计算
  
  你可以明白,

通过使用简单的DATEDIFF和DATEADD函数计算,你可以发现很多不同的可能有意义的日期。
  
   目前为止的所有例子只是仅仅计算当前的时间和“1900-01-01”之间的时间间隔数量,然后把它加到“1900-01-01”的时间间隔上来计算出 日期。假定你修改时间间隔的数量,或者使用不同的时间间隔来调用DATEADD函数,或者减去时间间隔而不是增加,那么通过这些小的调整你可以发现和多不 同的日期。
  
  这里有四个例子使用另外一个DATEADD函数来计算最后一天来分别替换DATEADD函数前后两个时间间隔。
  上个月的最后一天
  
  这是一个计算上个月最后一天的例子。它通过从一个月的最后一天这个例子上减去3毫秒来获得。有一点要记住,在Sql Server中时间是精确到3毫秒。这就是为什么我需要减去3毫秒来获得我要的日期和时间。
  
  Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))
  
  计算出来的日期的时间部分包含了一个Sql Server可以记录的一天的最后时刻(“23:59:59:997”)的时间。
  
  去年的最后一天
  
  连接上面的例子,为了要得到去年的最后一天,你需要在今年的第一天上减去3毫秒。
  
  Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))
  
  本月的最后一天
  
   现在,为了获得本月的最后一天,我需要稍微修改一下获得上个月的最后一天的语句。修改需要给用DATEDIFF比较当前日期和“1900-01-01” 返回的时间间隔上加1。通过加1个月,我计算出下个月的第一天,然后减去3毫秒,这样就计算出了这个月的最后一天。这是计算本月最后一天的SQL脚本。
  
  Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))
  
  本年的最后一天
  
  你现在应该掌握这个的做法,这是计算本年最后一天脚本
  
  Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))。
  
  本月的第一个星期一
  
  好了,现在是最后一个例子。这里我要计算这个月的第一个星期一。这是计算的脚本。
  
  select DATEADD(wk, DATEDIFF(wk,0,
  dateadd(dd,6-datepart(day,getdate()),getdate())
  ), 0)
  
  在这个例子里,我使用了“本周的星期一”的脚本,并作了一点点修改。修改的部分是把原来脚本中“getdate()”部分替换成计算本月的第6天,在计算中用本月的第6天来替换当前日期使得计算可以获得这个月的第一个星期一。
  
  总结
  
   我希望这些例子可以在你用DATEADD和DATEDIFF函数计算日期时给你一点启发。通过使用这个计算日期的时间间隔的数学方法,我发现为了显示两 个日期之间间隔的有用历法是有价值的。注意,这只是计算出这些日期的一种方法。要牢记,还有很多方法可以得到相同的计算结果。假如你有其他的方法,那很不 错,要是你没有,我希望这些例子可以给你一些启发,当你要用DATEADD和DATEDIFF函数计算你程序可能要用到的日期时。
  ---------------------------------------------------------------
  附录,其他日期处理方法
  
  1)去掉时分秒
  declare @ datetime
  set @ = getdate() --''2003-7-1 10:00:00''
  Select @,DATEADD(day, DATEDIFF(day,0,@), 0)
  
  2)显示星期几
  select datename(weekday,getdate())
  
  3)如何取得某个月的天数
  declare @m int
  set @m=2 --月份
  select datediff(day,''2003-''+cast(@m as varchar)+''-15'' ,''2003-''+cast(@m+1 as varchar)+''-15'')
  另外,

取得本月天数
   select datediff(day,cast(month(GetDate()) as varchar)+''-''+cast(month(GetDate()) as varchar)+''-15'' ,cast(month(GetDate()) as varchar)+''-''+cast(month(GetDate())+1 as varchar)+''-15'')
  或者使用计算本月的最后一天的脚本,然后用DAY函数区最后一天
  Select Day(dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0)))
  
  4)判断是否闰年:
  Select case day(dateadd(mm, 2, dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)))) when 28 then ''平年'' else ''闰年'' end
  或者
  select case datediff(day,datename(year,getdate())+''-02-01'',dateadd(mm,1,datename(year,getdate())+''-02-01''))
  when 28 then ''平年'' else ''闰年'' end
  
  5)一个季度多少天
  declare @m tinyint,@time smalldatetime
  select @m=month(getdate())
  select @m=case when @m between 1 and 3 then 1
  when @m between 4 and 6 then 4
  when @m between 7 and 9 then 7
  else 10 end
  select @time=datename(year,getdate())+''-''+convert(varchar(10),@m)+''-01''
  select datediff(day,@time,dateadd(mm,3,@time))

  作者Blog:http://blog.csdn.net/xpilot/


附:我在实际应用中的例子:


获取本月的点击,使用第一部分提供的方法,即detepart
select * from news_hits where DATEPART(mm, ReadTime) = DATEPART(mm, GETDATE()) and DATEPART(yy, ReadTime) = DATEPART(yy, GETDATE())


获取本月的点击,使用来自于asp(vbscript)的思维,即datediff
select * from news_hits where DATEDIFF(MM,ReadTime,GETDATE())=0  --DATEPART(mm, ReadTime) = DATEPART(mm, GETDATE()) and DATEPART(yy, ReadTime) = DATEPART(yy, GETDATE())

获取本周的点击
select * from news_hits where DATEDIFF(WW,ReadTime,GETDATE())=0

获取本周的第一天(来自于第三部分的方法)
Select DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)

分享到:
评论

相关推荐

    sql语句查询周月年季的最后或第一天

    ### 二、SQL语句实现周、月、年、季度的第一天和最后一天 #### 1. 查询某个月的第一天和最后一天 - **第一天**: ```sql SELECT DATEADD(day, -DATEPART(day, GETDATE()) + 1, GETDATE()) ``` 或者 ```sql ...

    Sql语句 查询本周记录\本月记录\本季度记录\本年记录

    SQL 语句查询本周记录、本月记录、本季度记录、本年记录是数据库查询中...本文提供了 MySQL 和 SQL Server 两种数据库管理系统的查询语句,可以帮助您快速实现查询本周记录、本月记录、本季度记录、本年记录等操作。

    SQL按照日、周、月、年统计数据的方法分享

    这里我们将详细探讨如何按照日、周、月、季度和年来统计销售额或其他指标,以SQL语句为例。 首先,我们来看如何按照日来统计销售额。假设我们有一个名为`consume_record`的表,其中包含`consume`字段表示销售额,...

    与时间相关的SQL语句

    ### 与时间相关的SQL语句知识点详解 #### 1. 获取当前系统日期和时间 - **函数**: `GETDATE()` - **用途**: 返回当前系统的日期和时间。 - **示例**: ```sql SELECT GETDATE(); ``` #### 2. DATEADD - 添加...

    常用sql语句汇总

    这篇文档“常用sql语句汇总”将涵盖多个与SQL相关的主题,包括处理死锁、BCP数据导入导出、动态生成日期维度以及如何断开并更改数据库名称等关键知识点。 首先,我们来探讨死锁。死锁是数据库系统中常见的问题,...

    sql日期处理的函数大全

    在SQL中,日期和时间处理是数据库操作中的关键部分,特别是在需要进行数据分析、报表生成以及时间敏感性查询的场景下。以下是对SQL日期处理函数的全面解析,这些函数包括获取当前系统时间、修改日期时间值、计算日期...

    整理的SQL日期函数语句

    12. **查询特定月份、周、季度的记录**:在SQL查询中,可以利用`DATEPART`来筛选特定日期范围的记录,例如查询本年的记录、本周的记录或者本季度的记录。 13. **获取当月总天数**:可以通过`DATEDIFF`函数计算下个...

    工资发放日期关于payday的三个sql语句

    6. **日期和时间函数**:SQL提供了处理日期和时间的函数,如`DATE`, `MONTH`, `YEAR`, `DAYOFMONTH`等,可能在这些SQL语句中用于提取、比较或计算工资发放日期。 7. **数据排序**:`ORDER BY`子句可能会被用来按...

    sql查本周本月本季的方法

    上一周的起始日期和结束日期可以通过以下SQL语句来确定: ```sql -- 获取上一周的起始日期(周一) SELECT DATEADD(wk, DATEDIFF(wk, 0, GETDATE()) - 2, 0) AS StartOfWeek; -- 获取上一周的结束日期(周日) ...

    Java 连续日期周期作为sql查询条件

    如果你需要处理更复杂的日期周期,例如按周、月或季度,可以使用`YearMonth`类来处理。例如,获取当前月的第一天和最后一天: ```java YearMonth currentMonth = YearMonth.now(); LocalDate firstDayOfMonth = ...

    sql中的按日期统计问题

    在SQL(结构化查询语言)中,处理按日期统计的问题是一项常见的任务,特别是在数据分析、报表生成和业务智能领域。这类问题通常涉及到从数据库中提取特定日期范围内的数据,或者计算不同日期区间的数据量。以下是对...

    SQL Server各种日期计算

    在探讨SQL Server中进行日期计算的方法之前,我们必须了解SQL Server中处理日期和时间的基本函数:DATEDIFF和DATEADD。这两个函数在实际应用中非常常用,可以帮助我们得到两个日期间的时间间隔以及通过已知时间间隔...

    Sql memo日常查询语句应用

    根据给定的信息,本文将对几个SQL语句的应用进行详细解析。主要分为以下几个部分: ### 一、使用动态SQL查询汇总结果 #### 背景介绍 在实际业务场景中,有时我们需要根据不同的条件来动态生成SQL语句,以便获取...

    oracle 时间相关的sql语句

    根据提供的文件信息,本文将详细解释Oracle数据库中与时间相关的SQL语句,这些语句能够帮助用户处理诸如“上月当日”、“本月初”、“上月初”、“去年今天”等日期计算需求。以下是对每一条SQL语句的解析: ### 1....

    SQLServer时间处理

    在SQL Server中,时间处理是数据库管理中的一个重要环节,它涉及到如何存储、操作和查询与时间相关的数据。本文将深入探讨SQL Server中的时间处理技术,包括时间数据类型的使用、时间值的转换、以及如何获取特定时间...

    SQL日期获取技巧大全

    在SQL中,日期处理是常见的任务,特别是在数据分析...通过以上SQL语句,你可以灵活地处理日期并获取所需的信息,无论是用于报告、分析还是其他业务需求。理解并熟练运用这些技巧,将大大提升你在处理日期数据时的效率。

    使用简单的SQL语句实现的Oracle数据库分页技术

    本文将介绍一种利用简单SQL语句来实现Oracle数据库分页的方法,这种方法不依赖于复杂的PL/SQL过程或函数,而是通过SQL查询的巧妙设计来达到目的。 ### 分页公式的原理 在Oracle中,分页查询通常涉及到对结果集进行...

    SQL日期的方法及例子

    例如,向日期'2004-10-15'增加2天的SQL语句是:`SELECT DATEADD(day, 2, '2004-10-15')`,结果为'2004-10-17 00:00:00.000'。 3. **DATEDIFF函数**: `DATEDIFF(interval, date1, date2)`返回两个日期之间按照指定...

    SQL Server各种日期计算方法

    例如,获取当前日期所在月份的第一天可以使用以下SQL语句: ```sql SELECT DATEADD(mm, DATEDIFF(mm, 0, GETDATE()), 0) ``` 这里`DATEDIFF(mm, 0, GETDATE())`用于计算从1900年1月1日至当前日期的月份数量,然后...

Global site tag (gtag.js) - Google Analytics