MS SQL Server 时间函数

日期和时间数据类型
数据类型
存储(字节)

日期范围 精确度 格式示例
DateTime 8 1753年1月1日 - 9999年12月31日 3 1/3毫秒 yyyy-MM-dd hh:mm:ss.nnn
smalldatetime 4 1900年1月1日 - 2079年6月6日 1分钟 yyyy-MM-dd hh:mm
date 3 0001年1月1日 - 9999月12月31日 1天 yyyy-MM-dd
time 3-5 N/A 100纳秒 hh:mm:ss.nnnnnnn
DateTime2 6-8 0001年1月1日 - 9999年12月31日 100纳秒 yyyy-MM-dd hh:mm:ss.nnnnnnn
Datetimeoffset 8-10 0001年1月1日 -- 9999年12月31日 100纳秒 yyyy-MM-dd hh:mm:ss.nnnnnnn

-- 1、时间和日期函数 除了CURRENT_TIMESTAMP 函数不置顶小括号"()";其他的函数都需要制定小括号

select GETDATE() --返回当前时间
select CURRENT_TIMESTAMP -- 等同于getdate(),但是遵循ANSI SQL
select GETUTCDATE() -- 返回UTC日期和时间(协调世界时 )
select SYSDATETIME() -- 当前日期和时间
select SYSUTCDATETIME() -- 当前UTC日期和时间(协调世界时)
select SYSDATETIMEOFFSET() -- 包含时区偏移量的当前日期时间

-- 2、cast、convert函数,及其Try_对应函数 TRY_函数在SQL Sever2012开始支持
-- cast、convert函数用于将输入值转换为目标类型,如果转换成功输出转换的值,否则报错;
-- try_cast、try_convert函数;两个个try_函数与其对应的函数功能作用一样,不同的是如果不能讲输入的值转换为指定类型,函数返回NULL.

select CAST(‘20160628‘ AS DATE)
select TRY_CAST(‘20160628‘ AS DATE)

select CAST(‘123456‘ as DATE)
select Try_CAST(‘123456‘ as DATE)

select CONVERT(char(10),GETDATE(),120)
select Try_CONVERT(char(10),GETDATE(),120)

select CONVERT(int,‘123acb‘)
select Try_CONVERT(int,‘123acb‘)

-- 3、switchoffset函数将输入的datetimeoffset时间调整为指定的时区时间
select switchoffset(sysdatetimeoffset(),‘-05:00‘) --查询-05:00 时区时间
select SWITCHOFFSET(SYSDATETIMEOFFSET(),‘+00:00‘) --查询UTC时间

-- 4、Todatetimeoffset函数;设置输入的日期和时间值得时区偏移量
select TODATETIMEOFFSET(SYSDATETIMEOFFSET(),-10)

-- 5、DateAdd函数;允许为指定的日期部分增加一个指定的单位的单位数量到输入的日期和时间值中。
select DATEADD(YEAR,1,‘2016-06-28‘) --指定日期加1年 2017-06-28
select DATEADD(QUARTER,1,‘2016-06-28‘) --指定日期加3个月206-09-28
select DATEADD(MONTH,-1,‘2016-06-28‘) --指定日期减1个月2016-05-28
select DATEADD(DAY,1,‘2016-06-28‘) --指定日期加1天2016-06-29
select DATEADD(WEEK,1,‘2016-06-28‘) --指定日期加7天2016-07-05
select DATEADD(HOUR,1,‘2016-06-28 21:00:00.000‘) -- 指定时间加1小时 2016-06-28 22:00:00.000
select DATEADD(MINUTE,1,‘2016-06-28 21:00:00.000‘) -- 指定时间加1分钟 2016-06-28 21:01:00.000
select DATEADD(SECOND,1,‘2016-06-28 21:00:00.000‘) -- 指定时间加1秒钟 2016-06-28 21:00:01.000
select DATEADD(MILLISECOND,10,‘2016-06-28 21:00:00.000‘) --指定时间加10毫秒 2016-06-28 21:00:00.010

-- 6、DateDiff(part,val1,val2)函数;返回val2-val1返回指定单位的数量
select DateDiff(YEAR,‘2011-06-28‘,‘2017-06-28‘)
select DateDiff(QUARTER,‘2016-03-28‘,‘2016-06-28‘)
select DateDiff(MONTH,‘2016-05-28‘,‘2016-06-28‘)
select DateDiff(DAY,‘2016-06-27‘,‘2016-06-28‘)
select DateDiff(WEEK,‘2016-06-21‘,‘2016-06-28‘)
select DateDiff(HOUR,‘2016-06-28 20:00:00.000‘,‘2016-06-28 21:00:00.000‘)
select DateDiff(MINUTE,‘2016-06-28 21:01:00.000‘,‘2016-06-28 21:00:00.000‘)
select DateDiff(SECOND,‘2016-06-28 21:00:01.000‘,‘2016-06-28 21:00:00.000‘)
select DateDiff(MILLISECOND,‘2016-06-28 21:00:00.001‘,‘2016-06-28 21:00:00.000‘)

-- 7、datepart函数;返回一个日期或时间部分的整数部分;
select DATEPART(YEAR,‘2016-06-28‘)
select DATEPART(MONTH,‘2016-06-28‘)
select DATEPART(WEEK,‘2016-06-28‘)
select DATEPART(DAY,‘2016-06-28‘)
select DATEPART(HOUR,‘2016-06-28 21:01:02‘)
select DATEPART(MINUTE,‘2016-06-28 21:01:02‘)
select DATEPART(SECOND,‘2016-06-28 21:01:02‘)
select DATEPART(MILLISECOND,‘2016-06-28 21:01:02:100‘)

-- 8、year、month和day函数;和datepart函数一样;返回年、月、日期的整数
select YEAR(‘2016-06-28‘)
select month(‘2016-06-28‘)
select day(‘2016-06-28‘)

-- 9、datename函数;与datepart类似;但是返回的不是数字而是名称,根据操作系统的语言返回指定的日期名称;例如英文操作系统中 DATENAME(MONTH,‘2016-06-28‘) 返回june
select DATENAME(year,‘2016-06-28‘)
select DATENAME(MONTH,‘2016-06-28‘)
select DATENAME(DAY,‘2016-06-28‘)
select DATENAME(HOUR,‘2016-06-28 21:01:02‘)
select DATENAME(MINUTE,‘2016-06-28 21:01:02‘)
select DATENAME(SECOND,‘2016-06-28 21:01:02‘)
select DATENAME(MILLISECOND,‘2016-06-28 21:01:02:100‘)

-- 10、isdate函数;判断输入的字符串是否能转换为日期或时间;true 为1;false为0
select ISDATE(‘2016-06-28‘) --true
select ISDATE(‘2016-06-282‘) --false

select ISDATE(‘2016-06-28 21:00:00.000‘) --true
select ISDATE(‘2016-06-28 21:00:00.0000‘) --false

时间: 2024-10-05 05:06:52

MS SQL Server 时间函数的相关文章

SQL Server ->> 时间函数: EOMONTH, DATEFROMPARTS, TIMEFROMPARTS, DATETIMEFROMPARTS, DATETIMEOFFSETFROMPARTS

上面几个函数都是SQL Server 2012新增的时间函数. EOMONTH 返回传入时间的月结束日,返回数据类型为DATE SELECT EOMONTH(GETDATE()) 结果为 2016-01-31 DATEFROMPARTS 如同C#或者Java声明一个DATETIME实例那样通过传入YEAR, MONTH, DAY的数字值得到一个DATETIME的实例.这里也是一样.通过传入年月日来得到一个DATE.但是如果你一旦传入的参数无法构造出一个合法的时间,就会报错. DECLARE @Y

iBatis自动生成的主键 (Oracle,MS Sql Server,MySQL)【转】

iBatis的sqlMap配置文件的selectKey元素有个type属性,可以指定pre或者post表示前生成(pre)还是后生成(post). Oracle设置 Xml代码   <!-- Oracle SEQUENCE --> <insert id="insertProduct-ORACLE" parameterClass="com.domain.Product"> <selectKey resultClass="int&

数据库开发基础-SQl Server 聚合函数、数学函数、字符串函数、时间日期函数

SQL 拥有很多可用于计数和计算的内建函数. 函数的语法 内建 SQL 函数的语法是: SELECT function(列) FROM 表 函数的类型 在 SQL 中,基本的函数类型和种类有若干种.函数的基本类型是: Aggregate 函数 Scalar 函数 合计函数(Aggregate functions) Aggregate 函数的操作面向一系列的值,并返回一个单一的值. 注释:如果在 SELECT 语句的项目列表中的众多其它表达式中使用 SELECT 语句,则这个 SELECT 必须使

MS SQL Server带有时间的记录怎样查询

原文:MS SQL Server带有时间的记录怎样查询 比如某一张表[A]有一个保存日期包含时间字段[B],如果以这个段[B]作查询条件对数据记录进行查询.也我们得花些心思才能查询到我们想得到的记录. 现在我们需要查询这天2014-06-21的所有记录: SELECT * FROM [A] WHERE [B] = '2014-06-21' 上面的语法,将查询不到任何记录.也许会有网友想到使用BETWEEN: SELECT * FROM [A] WHERE [B] BETWEEN '2014-06

用SQL语句查找包含有某个关键字的存储过程、触发器、函数等(仅适用MS SQL SERVER)

原文:用SQL语句查找包含有某个关键字的存储过程.触发器.函数等(仅适用MS SQL SERVER) 第一种方法:利用系统表进行查询 --将text替换成你要查找的内容 select name from sysobjects o, syscomments s where o.id = s.id and text like '%text%' and o.xtype = 'P' xtype:对象类型.可以是下列对象类型中的一种: C = CHECK 约束 D = 默认值或 DEFAULT 约束 F

MS SQL Server的LTRIM,RTRIM和TRIM函数

在MS SQL Server 2017有了一个新函数TRIM,整合以前版本LTRIM和RTRIM. 这几个函数都是去除字符串头部后尾部的空格. DECLARE @str NVARCHAR(MAX) = N' Insus.NET ' SELECT @str AS [str], [dbo].[svf_StringLength](@str) AS [length] SELECT LTRIM(@str) AS [str], [dbo].[svf_StringLength](LTRIM(@str)) AS

四个很好用的Sql Server 日期函数:DateDiff、DatePart、DateAdd、DateName

我以前查一段时间范围内的数据都是在程序里计算好日期再掉查询语句,现在我用下面的函数.SQL SERVER没有查一季度数据的函数. DateDiff函数: 描述 返回两个日期之间的时间间隔. 语法 DateDiff(interval, date1, date2 [,firstdayofweek[, firstweekofyear]]) DateDiff 函数的语法有以下参数: 参数 描述 interval 必选.字符串表达式,表示用于计算 date1 和 date2 之间的时间间隔.有关数值,请参

sql server 时间小汇

SQL server DATE函数 (1)getdate   返回当前系统的日期和时间,精确到3毫秒 要求:获得系统的当前时间 语句:SELECT getdate() 执行结果: 注:getutcdate():用于返回服务器当前日期和时间对应的格林威治时间,精确到3毫秒.他对于跨时区的公司非常有用. (2)dateadd   在制定日期基础上加上或减去一段时间,返回新的datetime 要求:在2008-10-12日上加上2天 语句:SELECT dateadd(day,2,'2008-10-1

SQL Server日期函数总结

获得一个月的天数:首先到得一个月最后一天的日期,通过 SQL Server 日期函数 day() 取得日期中的“天 ”部分 获得 2008 年 2 月份的天数:select day(cast('2008-03-01' as datetime) - 1) 获得本月天数: 返回一个整数,该整数表示指定的 date 是该月份的哪一天. select day(dateadd(month,1,getdate()) - day(getdate())) 获得上个月天数:select day(getdate()