求本年、本月、本周等数据

简介: 本文转载:http://www.cnblogs.com/ethan-qi/archive/2013/05/14/3077371.html 其他关于SQL获取时间的方法:http://www.cnblogs.

本文转载:http://www.cnblogs.com/ethan-qi/archive/2013/05/14/3077371.html

其他关于SQL获取时间的方法:http://www.cnblogs.com/ethan-qi/archive/2012/04/23/2466292.html

select * from tbl where DATEPART(wk,date_field) = DATEPART(wk,getDate()) And DATEPART(yyyy,date_field) = DATEPART(yyyy,getDate())--周  select * from tbl where DATEPART(m,date_field) = DATEPART(m,getDate()) And DATEPART(yyyy,date_field) = DATEPART(yyyy,getDate())--月  select * from tbl where DATEPART(q,date_field) = DATEPART(q,getDate()) And DATEPART(yyyy,date_field) = DATEPART(yyyy,getDate()) --季  select * from tbl where DATEPART(yyyy,date_field) = DATEPART(yyyy,getDate()) --年

Access wk之类的加引号 "wk"

getDATE()是什么东东,可不可以用date()来代替? 在SQL中不能用date()代替  它在那相当于now()

举例一周的 select * from 表 where datediff(week,时间字段,getdate())=0

要注意的是,datediff是将星期日做为一周的第一天  即:datediff(week,'2003-07-27','2003-08-01')的值为0

如果你要求将星期一做为一周的第一天,就要用:  select * from 表 where datediff(week,时间字段+1,getdate()+1)=0

//=====================================================================//


1.一个月第一天的    Select   DATEADD(mm,   DATEDIFF(mm,0,getdate()),   0)   
2.本周一    Select   DATEADD(wk,   DATEDIFF(wk,0,getdate()),0) Select   dateadd(wk,datediff(wk,0,getdate()),6)  

 

3.一年的第一天    SELECT   DATEADD(yy,   DATEDIFF(yy,0,getdate()),   0)   
4.季度的第一天    SELECT   DATEADD(qq,   DATEDIFF(qq,0,getdate()),   0)   
5.当天的半夜    SELECT   DATEADD(dd,   DATEDIFF(dd,0,getdate()),   0)   
6.上个月的最后一天    SELECT   dateadd(ms,-3,DATEADD(mm,   DATEDIFF(mm,0,getdate()),   0))   
7.去年的最后一天    SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate()),   0))   
8.本月的最后一天    SELECT   dateadd(ms,-3,DATEADD(mm,   DATEDIFF(m,0,getdate())+1,   0))   
9. 本年的最后一天    SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate())+1,   0))   
10.本月的第一个星期一    select   DATEADD(wk,DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())),   0)

 

11.查询本周注册人数    select count(*) from [user] where datediff(week,create_day-1,getdate())=0   
12.上周注册人数    select   count(*)   from   [user]   where   datediff(week,create_day-1,getdate())=1   

13.本月注册人数    select   count(*)   from   [user]   where   datediff(month,create_day,getdate())=0   
14.上月注册人数    select   count(*)   from   [user]    where   datediff(month,create_day,getdate())=1   
如果要效率,这样写查询
1.查询本周注册人数    select   count(*)   from   [user]    where   create_day>=dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112))    and   create_day<dateadd(day,9-datepart(weekday,getdate()),convert(varchar,getdate(),112))   
2.上周注册人数    select   count(*)   from   [user]    where   create_day>=dateadd(day,-5-datepart(weekday,getdate()),convert(varchar,getdate(),112))    and   create_day<dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112))   
 3.本月注册人数    select   count(*)   from   [user]    where   create_day>=dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))    and   create_day<dateadd(month,1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112)))   
4.上月注册人数    select   count(*)   from   [user]    where   create_day>=dateadd(month,-1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112)))    and   create_day<dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))   
5.本周    select   count(*)   from   User    where   datediff(dd,create_day,getdate())   <=   datepart(dw,getdate())   
6.上周    select   count(*)   from   User    where   datediff(dd,create_day,(getdate()   -   datepart(dw,getdate())))   <=   7   
7.本月    select   count(*)   from   User    where   datepart(mm,create_day)   =   datepart(mm,getdate())  

8.上月    select   count(*)   from   User    where   datepart(mm,create_day)   =   datepart(mm,getdate())   -   1

9.本周    select   count(*)   from   [User]    where   datediff(dd,create_day,getdate())   <=   datepart(dw,getdate())   
10.上周    select   count(*)   from   [User]    where   datediff(dd,create_day,(getdate()   -   datepart(dw,getdate())))   <=   7   
11.本月    select   count(*)   from   [User]    where   datepart(mm,create_day)   =   datepart(mm,getdate())    12. 上月    select   count(*)   from   [User]    where   datepart(mm,create_day)   =   datepart(mm,getdate())   -   1

  

网上取当月第一天和最后一天的SQL语句很多,有的是通过字符截取,有的是通过函数,个人还是比较偏向于使用内置函数来处理,

但是看了下网上的运用函数来取第一天和最后一天时间的SQL语句几乎都像下面这样的,其实是存在问题的,存在一个临界值得问题。


     本月第一天:select   dateadd(dd,-day(getdate())+1,getdate())  

   本月最后一天:select   dateadd(dd,-day(getdate()),dateadd(m,1,getdate()))
      上面的两句,第一句取第一天的完全没问题,第二句就有问题了,一般的想法是取最后一天,可以在当前时间上加一个月,然后减去当前时间的天数,比如随便 2009-8-27,加一个月就是2009-9-27,然后减去2009-8-27时间的天数27天 正好是2009-8-31,没问题呀。

       但是,如果当前时间本身就是最后一天的话,就会产生临界问题了,比如传入的实际是2009-5-31,最终得到的最后一天的时间其实也应该是 2009-5-31才对,如果按照上面的写法,2009-5-31加一个月是多少,2009-6-31?2009-7-1?都不是,由于月大月小的问 题,6月份只有30天,所以2009-5-31加一个月后是2009-6-30日,还是按上面的写法然后再减去2009-5-31时间的天数31天,最终 得到的最后一天是2009-5-30,傻眼了,咋回事啊?

        还有2月只有28或29天当然也会存在这样的问题,只要稍微改动一下,在减天数的时候不应减当前时间的天数,而应减去加了月份之后的天数,如下写法:
        select   dateadd(dd,-day(dateadd(m,1,getdate())),dateadd(m,1,getdate()))

        这样的话,即使6月没有31天,2009-6-30减去30天就是2009-5-31,再如2009-1-30加一个月是2009-2-28,减去28天后是2009-1-31符合正确性。

可以依此类推:


可以依此类推:

select   dateadd(dd,-day(dateadd(month,-1,getdate()))+1,dateadd(month,-1,getdate()))     /*上个月一号*/
select   dateadd(dd,-day(getdate()),getdate())                                                                      /* 上月月底 */
select   dateadd(dd,-day(getdate())+1,getdate())                                                                  /* 本月一号 */
select   dateadd(dd,-day(dateadd(month,1,getdate())),dateadd(month,1,getdate()))            /* 本月底 */
select   dateadd(dd,-day(dateadd(month,1,getdate()))+1,dateadd(month,1,getdate()))        /* 下月一号 */
select   dateadd(dd,-day(dateadd(month,2,getdate())),dateadd(month,2,getdate()))            /* 下月月底 */

如果想把时间格式转换成“yyyy/mm/dd hh:mi:ss”这种格式,可以:

select rtrim(convert(char,getdate(),111))+''+(convert(char,getdate(),108))  -- yyyy/mm/dd hh:mi:ss

 


测试:(列出上月开始和结束时间,然后转换时间格式)
 declare @time1 datetime,
              @time2 datetime,
              @time3  datetime,
              @time4 datetime

 
         set @time1 = dateadd(dd,-day(dateadd(month,-1,getdate()))+1,dateadd(month,-1,getdate())),    --上个月一号
               @time2 = dateadd(dd,-day(getdate())+1,getdate())               --本月一号
         set @time3 = rtrim(convert(char,@time1,111))+''+(convert(char,@time1,108)),
               @time4 = rtrim(convert(char,@time2,111))+''+(convert(char,@time2,108))
 
        select dateadd(dd,-day(dateadd(month,-1,getdate()))+1,dateadd(month,-1,getdate()))   
        select dateadd(dd,-day(getdate())+1,getdate()) 
        select rtrim(convert(char,@time1,111))+''+(convert(char,@time1,108))  -- yyyy/mm/dd hh:mi:ss
        select rtrim(convert(char,@time2,111))+''+(convert(char,@time2,108))  -- yyyy/mm/dd hh:mi:ss


输出结果:(sybase下)
Jan  1 2011  5:30PM                              
-                              
Feb  1 2011  5:30PM                                                                      
-                                                             
2011/01/01 17:30:58                                                                                                    
-                                                             
2011/02/01 17:30:58     

  

目录
相关文章
|
存储 对象存储 UED
CDN适用哪些场景?
CDN是将源站内容分发至最接近用户的节点,使用户可就近取得所需内容,提高用户访问的响应速度和成功率。今天为大家分享几个CDN的典型适用场景。
16734 0
|
数据安全/隐私保护 网络架构
CentOS8 Kibana8.x 安装遇到的问题解决
CentOS8 Kibana8.x 安装遇到的问题解决
846 0
CentOS8 Kibana8.x 安装遇到的问题解决
|
存储 缓存 Cloud Native
[Snowflake核心技术解读系列二]云原生技术
Snowflake取得了巨大的商业成功,技术是如何支撑起它的千亿美元市值呢?它技术强在哪?本文为大家倾情解读Snowflake的核心技术原理。
[Snowflake核心技术解读系列二]云原生技术
|
人工智能 Serverless 数据处理
通过图片视觉理解,结构化提取属性信息
邀请您参加图片信息提取挑战!使用AI技术提升数据处理效率,通过部署应用并上传图片信息截图,即可赢取南瓜蒲团坐垫,每日限量50个,先到先得。活动截止至2024年12月27日16:00。立即访问活动页面参与吧!
197 8
|
存储 缓存 监控
Elasticsearch集群JVM调优堆外内存
Elasticsearch集群JVM调优堆外内存
259 1
|
存储 分布式计算 算法
基于 Log 的通用增量 Checkpoint
本文将从 Checkpoint 的性能优化历程出发,介绍 ChangelogStateBackend 的基本机制、应用场景和未来规划,同时介绍最新版本在 State 上的一些优化工作。
7749 2
基于 Log 的通用增量 Checkpoint
|
存储 人工智能 机器人
通义大模型百炼融合AnalyticDB, 10分钟打造企业微信AI助手
通义大模型百炼融合AnalyticDB, 10分钟打造企业微信AI助手。只需简单几步,即可在企业微信集成AI助手,提升客户服务体验。参与“10分钟打造企业微信AI助手”活动,完成指定任务即可赢取定制礼品,数量有限,先到先得。
|
网络协议 网络安全 网络架构
ping命令详解
【8月更文挑战第14天】 ping命令详解
848 3
|
Java 数据库连接 数据库
AI 时代风起云涌,Hibernate 实体映射引领数据库高效之路,最佳实践与陷阱全解析!
【8月更文挑战第31天】Hibernate 是一款强大的 Java 持久化框架,可将 Java 对象映射到关系数据库表中。本文通过代码示例详细介绍了 Hibernate 实体映射的最佳实践,包括合理使用关联映射(如 `@OneToMany` 和 `@ManyToOne`)以及正确处理继承关系(如单表继承)。此外,还探讨了常见陷阱,例如循环依赖可能导致的无限递归问题,并提供了使用 `@JsonIgnore` 等注解来避免此类问题的方法。通过遵循这些最佳实践,可以显著提升开发效率和数据库操作性能。
262 0
|
SQL Java 数据处理
实时计算 Flink版产品使用合集之怎么热加载Java和Python的UDF
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
247 1