首页 > 数据库 >sql server 查询日期中的常用语句

sql server 查询日期中的常用语句

时间:2023-01-31 20:56:47浏览次数:49  
标签:语句 -- dd dateadd server DATEADD sql SELECT getdate

--本周第一天   
SELECT DATEADD(Day,1-(DATEPART(Weekday,getdate())+@@DATEFIRST-1)%7,getdate())  
--or   
select dateadd(wk, datediff(wk,0,getdate()), 0)  
--本周第一天   
select dateadd(wk, datediff(wk,0,getdate()), 6)  
   
--上月第一天   
SELECT CONVERT(CHAR(10),DATEADD(month,-1,DATEADD(dd,-DAY(GETDATE())+1,GETDATE())),111)  
--上月最后一天   
SELECT CONVERT(CHAR(10),DATEADD(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()),0)),111)+' 23:59:59'  
--本月第一天   
select dateadd(dd,-datepart(dd,getdate())+1,getdate())  
--本月最后一天   
select dateadd(dd,-datepart(dd,getdate()) ,dateadd(mm,1,getdate()))  
--本月天数   
select datediff(dd,dateadd(dd,-datepart(dd,getdate())+1,getdate()), dateadd(dd,-datepart(dd,getdate())+1,dateadd(mm,1,getdate())))  
--or   
select datepart(dd,dateadd(dd,-1,dateadd(mm,1,cast(cast(year(getdate()) as varchar)+'-'+cast(month(getdate()) as varchar)+'-01' as datetime))))  
   
--下月第一天   
select dateadd(dd,-datepart(dd,getdate())+1,dateadd(mm,1,getdate()))  
--下月最后一天   
SELECT CONVERT(CHAR(10),DATEADD(ms,-3,DATEADD(mm,DATEDIFF(m,0,getdate())+2,0)),111)+' 23:59:59'  
--季度第一天   
SELECT   DATEADD(qq,   DATEDIFF(qq,0,getdate()),   0)   
--季度最后一天(直接推算法)   
SELECT DATEADD(Day,-1,CONVERT(char(8),DATEADD(Month,1+DATEPART(Quarter,getdate())*3-Month(getdate()),getdate()),120)+'1')  
--季度的最后一天(CASE判断法)   
select DATEADD(Month,DATEPART(Quarter,getdate())*3-Month(getdate()),getdate())  
   
--本月第一个星期一   
SELECT DATEADD(wk, DATEDIFF(wk, '', DATEADD(dd, 6 - DAY(getdate()), getdate())), '')   
--去年最后一天   
SELECT   dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))   
--今年第一天   
SELECT   DATEADD(yy,   DATEDIFF(yy,0,getdate()),   0)   
--今年最后一天   
SELECT  dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1,0))  
   
--指定日期所在周的任意一天   
SELECT DATEADD(Day,@number-DATEPART(Weekday,@dt),@dt)--5.指定日期所在周的任意星期几   
--A.  星期天做为一周的第1天   
SELECT DATEADD(Day,@number-(DATEPART(Weekday,@dt)+@@DATEFIRST-1)%7,@dt)  
--B.  星期一做为一周的第1天   
SELECT DATEADD(Day,@number-(DATEPART(Weekday,@dt)+@@DATEFIRST-2)%7-1,@dt)  
---周内的第几日   
select datepart(weekday,getdate()) as 周内的第几日  
--年内的第几周   
select datepart(week,getdate()) as 年内的第几周  
--年内的第几季   
select datepart(quarter,getdate()) as 年内的第几季  

--判断某天是当月的第几周的sql函数   

 declare @date datetime
  set @date = '2023-01-31'
  select cast(datepart(mm,@date) as varchar(2)) + '月第' + cast((datepart(wk,@date) - datepart(wk,convert(varchar(7),@date,120) + '-01') + 1) as varchar(2)) + '周'

 

标签:语句,--,dd,dateadd,server,DATEADD,sql,SELECT,getdate
From: https://www.cnblogs.com/lgx5/p/17080731.html

相关文章

  • SQL Server 日常维护经典应用
    SQLServer日常维护常用的一些脚本整理。1.sqlserver开启clr权限:execsp_configure'clrenabled',1GORECONFIGUREGOALTERDATABASEHWMESTCSETTRUSTWORTHYON......
  • MySQL执行计划
    一、什么是MySQL执行计划在平时的开发工作中,少不了数据库的使用,那么就会涉及到sql语句,如何知道sql语句执行的过程,以及sql语句执行的性能,通过执行计划模拟优化器执行sql进......
  • mysql学习问题记录
    Q:MySQL在创建外键索引时,使用工具会出现创建完成但是闪一下就没了使用CONSTRAINT'外键索引名'FOREIGNKEY('xx')REFERENCES数据库名(xx)创建时,只会出现索引信......
  • 浅谈SQL Server 对于内存的管理
    简介   理解SQLServer对于内存的管理是对于SQLServer问题处理和性能调优的基本,本篇文章讲述SQLServer对于内存管理的内存原理。 二级存储(secondarystorage)......
  • sql server 数据库收缩
    1.数据库的相关属性在MS中创建数据库时会为数据库分配初始的大小(如下图:数据库和日志两个文件),随着数据库的使用文件会逐渐增大。数据库文件大小的增加有两种方式:自动增长......
  • sql生成连续日期(年份、月份、日期)
    1--=============================================2--Author:<Author,Jearay>3--Createdate:<CreateDate,2022/8/15>4--Description:......
  • Windows Server 2022 中文版、英文版下载 (updated Jan 2023)
    WindowsServer2022正式版,2023年1月更新,持续更新中...请访问原文链接:https://sysin.org/blog/windows-server-2022/,查看最新版。原创作品,转载请保留出处。作者主页......
  • sqlserver 数据库备份
    目标:实现数据库定时备份和删除效果图如下1.数据备份declare@filenamevarchar(255)select@filename='E:\MES-BAK\MES'+left(replace(replace(REPLACE(convert(varc......
  • MySQL------8.0新特性:公用表表达式
    公用表表达式(或通用表表达式)简称为CTE(CommonTableExpressions)。CTE是一个命名的临时结果集,作用范围是当前语句。CTE可以理解成一个可以复用的子查询,当然跟子查询还是有点......
  • MySQL查询不区分大小写的问题总结
    MySQL查询不区分大小写问题1.问题描述最近,笔者在开发FleaAuth模块的过程中,准备验证以注册的账号huazie进行登录的场景,结果以HUAZIE成功登录,而数据库中存储的账号是hua......