Sqlserver时间函数用法(二)

--1. 当前系统日期、时间
select getdate() --2015-01-06 09:27:27.277

--2.时间操作 dateadd 在向指定日期加上一段时间的基础上,返回新的 datetime 值
dateadd(datepart,number,date)
注:
datepart : year(yy, yyyy) | quarter(qq,q) | month(mm,m) | week(ww,wk) | day(dd,dy) | hour(h) | minute(mi,n) |
second (ss,s)| millisecond(ms)
date 参数是合法的日期表达式。number 是您希望添加的间隔数;对于未来的时间,此数是正数,对于过去的时间,此数是负数。
例:
select getdate()
select dateadd(year,1,getdate()) --2016-01-06 09:27:27.277
select dateadd(month,1,getdate()) --2017-02-06 09:27:27.277
select dateadd(day,1,getdate()) --2015-01-07 09:27:27.277
select dateadd(week,1,getdate()) --2015-01-13 09:27:27.277
select dateadd(weekday,1,getdate()) --2015-01-07 09:27:27.277
select dateadd(hour,1,getdate()) --2015-01-06 10:27:27.277
select dateadd(Minute,1,getdate()) --2015-01-06 09:28:27.277
select dateadd(Second,1,getdate()) --2015-01-06 09:28:28.277

--3. datediff 返回跨两个指定日期的日期和时间边界数。
datediff( date-part, startdate, enddate )
注:
datepart : year(yy, yyyy) | quarter(qq,q) | month(mm,m) | week(ww,wk) | day(dd,dy) | hour(h) | minute(mi,n) |
second (ss,s)| millisecond(ms)
startdate 和 enddate 参数是合法的日期表达式。
返回值:(enddate)-(startdate)
例:
select datediff(year,getdate(),dateadd(year,2,getdate())) --返回:2
SELECT * FROM crm_contract where datediff(month,Subtime,getdate())=0 --查看crm_contract申请时间subtime是本月的数据

--4. datepart 函数用于返回日期/时间的单独部分,比如年、月、日、小时、分钟等等。
--如果需要得到自己需要的日期,则需要讲日期时间格式化
SELECT DATEPART(year, getdate()) as ‘年份‘
SELECT DATEPART(month, getdate()) as ‘月份‘
SELECT DATEPART(day, getdate()) as ‘日期‘
SELECT DATEPART(week, getdate()) as ‘本年第几周数‘
SELECT (DATEPART(weekday, getdate())-1) as ‘今天是周几?‘
SELECT DATEPART(hour, getdate()) as ‘小时‘
SELECT DATEPART(Minute, getdate()) as ‘分钟‘
SELECT DATEPART(Second, getdate()) as ‘秒时‘

--5. datename 返回代表指定日期的指定日期部分的字符串
SELECT datename(weekday, getdate()) as ‘今天是星期几?‘
SELECT datename(month,convert(varchar(10), getdate(),126)) as ‘今天是几月份?‘
SELECT datename(day,convert(varchar(10), getdate(),126)) as ‘今天是几号?‘
SELECT datename(year,convert(varchar(10), getdate(),126)) as ‘今年是哪年?‘

--上周周一
SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()),-7)
--上周周天
SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()),-1)
--.本周周一
SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()),0)
--.本周周天
select dateadd(wk,datediff(wk,0,getdate()),6)
--下周周一
select dateadd(wk,datediff(wk,0,getdate()),7)
--下周周天
select dateadd(wk,datediff(wk,0,getdate()),13)
--1.本月第一天
SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)

--.本月最后一天
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))
--.本周星期一
SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)

--.本周星期天
select dateadd(wk,datediff(wk,0,getdate()),6)

--.本年第一天
SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)

--.本年最后一天
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))
--.本季度第一天
SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)

--.当天的半夜
SELECT DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)

--.上个月的最后一天
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))

--.去年的最后一天
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))

--.本月的第一个星期一
select DATEADD(wk,
DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0)

时间: 2024-10-18 02:54:23

Sqlserver时间函数用法(二)的相关文章

SQLSERVER 时间函数汇总

1.求当天的年份 (getdate(): 2012/05/08 18:07:26)    SELECT YEAR(GETDATE())     --20122. 求当天的月份       SELECT MONTH(GETDATE())   --53. 求当天的日     SELECT DAY(GETDATE())      --84. 求年月日    SELECT CONVERT(VARCHAR,GETDATE(),112)  --结果:20120508    SELECT CONVERT(VA

sqlite sqlserver 时间函数

--------------------------------------------------------------------- whereSql := 'substr(f_billNumber,1,4)=' + QuotedStr(yymm)  else    whereSql := 'left(f_billNumber,4)=' + QuotedStr(yymm); ----------------------------------------------------------

Oracle中的时间函数用法(to_date、to_char) (总结)

一.24小时的形式显示出来要用HH24 select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from dual; select to_date('2005-01-01 13:14:20','yyyy-MM-dd HH24:mi:ss') from dual; 二.to_date() function 1.日期格式参数含义说明 D一周中的星期几 DAY天的名字,使用空格填充到9个字符 DD月中的第几天 DDD年中的第几天 DY天的简写名 IW ISO标准

SQLServer日期函数用法

--1.显示本月第一天 1 SELECT DATEADD(mm,DATEDIFF(mm,0,getdate()),0) 2 3 select convert(datetime,convert(varchar(8),getdate(),120)+'01',120) --2.显示本月最后一天 1 select dateadd(day,-1,convert(datetime,convert(varchar(8),dateadd(month,1,getdate()),120)+'01',120)) 2

c++ 时间函数用法

C++对时间的操作也有许多值得大家注意的地方.最近,在技术群中有很多网友也多次问到过C++语言中对时间的操作.获取和显示等等的问题.下面,在这篇文章中,笔者将主要介绍在C/C++中时间和日期的使用方法. 通过学习许多C/C++库,你可以有很多操作.使用时间的方法.但在这之前你需要了解一些"时间"和"日期"的概念,主要有以下几个: Coordinated Universal Time(UTC):协调世界时,又称为世界标准时间,也就是大家所熟知的格林威治标准时间(Gre

sql 时间函数用法

v\:* {behavior:url(#default#VML);} o\:* {behavior:url(#default#VML);} w\:* {behavior:url(#default#VML);} .shape {behavior:url(#default#VML);} IF(g.give_integral > -1, g.give_integral, c.goods_price) 这个函数的结果要根据g.give_integral的值,如果g.give_integral大于-1函数

常用的函数整理1(ip,时间函数,二维码)

function GetIP(){ if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown")) $ip = getenv("HTTP_CLIENT_IP"); else if (getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(gete

SQLSERVER时间函数

--2018select datepart(YEAR,GETDATE()) --8(年份)select datepart(MONTH,GETDATE()) --6(月份)select datepart(DAY,GETDATE()) --08  6 2018  6:30PMSELECT CONVERT(VARCHAR(100), GETDATE(), 0) --08/06/18    SELECT CONVERT(VARCHAR(100), GETDATE(), 1) --18.08.06SELE

PHP 中日期时间函数 date() 用法总结

[导读] date()是我们常用的一个日期时间函数,下面我来总结一下关于date()函数的各种形式的用法,有需要学习的朋友可参考.格式化日期date() 函数的第一个参数规定了如何格式化日期 时间.它使用字母来表示日期和时间 格式化日期date() 函数的第一个参数规定了如何格式化日期/时间.它使用字母来表示日期和时间的格式.这里列出了一些可用的字母: •d - 月中的天 (01-31)•m - 当前月,以数字计 (01-12)•Y - 当前的年(四位数)您可以在我们的 PHP Date 参考手