SQL Server 日期和时间数据类型及函数

日期和时间数据类型

下表列出了 SQL 的日期和时间数据类型:

数据类型格式范围精确度存储大小(字节)用户定义的秒的小数部分精度时区偏移量
timehh:mm:ss[.nnnnnnn]00:00:00.0000000 到 23:59:59.9999999100 纳秒3 到 5
dateYYYY-MM-DD0001-01-01 到 31.12.991 天3
smalldatetimeYYYY-MM-DD hh:mm:ss1900-01-01 到 2079-06-061 分钟4
datetimeYYYY-MM-DD hh:mm:ss[.nnn]1753-01-01 到 9999-12-310.00333 秒8
datetime2YYYY-MM-DD hh:mm:ss[.nnnnnnn]0001-01-01 00:00:00.0000000 到 9999-12-31 23:59:59.9999999100 纳秒6 到 8
datetimeoffsetYYYY-MM-DD hh:mm:ss[.nnnnnnn] [+|-]hh:mm0001-01-01 00:00:00.0000000 到 9999-12-31 23:59:59.9999999(以 UTC 时间表示)100 纳秒8 到 10

 备注

rowversion数据类型不是日期或时间数据类型。 SQL timestamp 是 rowversion 的已弃用同义词。

日期和时间函数

下表列出了 SQL 的日期和时间函数。 有关确定性的详细信息,请参阅确定性函数和非确定性函数

返回系统日期和时间值的函数

SQL transact-sql 从运行 SQL Server 实例的计算机的操作系统中派生所有系统日期和时间值。

精度较高的系统日期和时间函数

SQL Server 2019 () 通过使用 GetSystemTimeAsFileTime () Windows API 来派生日期和时间值。 准确性取决于运行 SQL Server 实例的 Windows 的计算机硬件和版本。 此 API 的精确度固定为 100 纳秒。 可使用 GetSystemTimeAdjustment() Windows API 确定该精确度。

函数语法返回值返回数据类型确定性
SYSDATETIMESYSDATETIME ()返回一个datetime2 (7) 值,该值包含 SQL Server 的实例在其上运行的计算机的日期和时间。 返回值不包括时区偏移量。datetime2(7)不具有确定性
SYSDATETIMEOFFSETSYSDATETIMEOFFSET ( )返回datetimeoffset (7) 值,该值包含运行 SQL Server 实例的计算机的日期和时间。 返回值包括时区偏移量。datetimeoffset(7)不具有确定性
SYSUTCDATETIMESYSUTCDATETIME ( )返回一个datetime2 (7) 值,该值包含运行 SQL Server 实例的计算机的日期和时间。 该函数返回日期和时间作为 UTC 时间(协调世界时)。datetime2(7)不具有确定性

精度较低的系统日期和时间函数

函数语法返回值返回数据类型确定性
CURRENT_TIMESTAMPCURRENT_TIMESTAMP返回一个日期/时间值,该值包含运行实例的计算机的SQL Server时间。 返回值不包括时区偏移量。datetime不具有确定性
GETDATEGETDATE ( )返回一个日期/时间值,该值包含运行实例的计算机的SQL Server时间。 返回值不包括时区偏移量。datetime不具有确定性
GETUTCDATEGETUTCDATE ( )返回一个日期/时间值,该值包含运行实例的计算机的SQL Server时间。 该函数返回日期和时间作为 UTC 时间(协调世界时)。datetime不具有确定性

返回日期和时间部分的函数

函数语法返回值返回数据类型确定性
DATENAMEDATENAME ( datepart , date )返回表示指定 date 的指定 datepart 的字符串。nvarchar不具有确定性
DATEPARTDATEPART ( datepart , date )返回表示指定 date 的指定 datepart 的整数。int不具有确定性
DAYDAY ( date )返回表示指定 date 的“日”部分的整数。intDeterministic
MONTHMONTH ( date )返回表示指定 date 的“月”部分的整数。intDeterministic
YEARYEAR ( date )返回表示指定 date 的“年”部分的整数。intDeterministic

从相应部分返回日期和时间值的函数

函数语法返回值返回数据类型确定性
DATEFROMPARTSDATEFROMPARTS ( year, month, day )返回表示指定年、月、日的 date 值。dateDeterministic
DATETIME2FROMPARTSDATETIME2FROMPARTS ( year, month, day, hour, minute, seconds, fractions, precision)对指定的日期和时间返回 datetime2 值(具有指定精度)。datetime2( precision )Deterministic
DATETIMEFROMPARTSDATETIMEFROMPARTS ( year, month, day, hour, minute, seconds, milliseconds)为指定的日期和时间返回 datetime 值。datetimeDeterministic
DATETIMEOFFSETFROMPARTSDATETIMEOFFSETFROMPARTS ( year, month, day, hour, minute, seconds, fractions, hour_offset, minute_offset, precision)对指定的日期和时间返回 datetimeoffset 值(具有指定的偏移量和精度)。datetimeoffset( precision )Deterministic
SMALLDATETIMEFROMPARTSSMALLDATETIMEFROMPARTS ( year, month, day, hour, minute )为指定的日期和时间返回 smalldatetime 值。smalldatetimeDeterministic
TIMEFROMPARTSTIMEFROMPARTS ( hour, minute, seconds, fractions, precision )对指定的时间返回 time 值(具有指定精度)。time( precision )具有确定性

返回日期和时间差异值的函数

函数语法返回值返回数据类型确定性
DATEDIFFDATEDIFF ( datepart , startdate , enddate )返回两个指定日期之间所跨的日期或时间 datepart 边界数。intDeterministic
DATEDIFF_BIGDATEDIFF_BIG ( datepart , startdate , enddate )返回两个指定日期之间所跨的日期或时间 datepart 边界数。bigintDeterministic

用来修改日期和时间值的函数

函数语法返回值返回数据类型确定性
DATEADDDATEADD (datepart , number , date )通过将一个时间间隔与指定 date 的指定 datepart 相加,返回一个新的 datetime 值。date 参数的数据类型Deterministic
EOMONTHEOMONTH ( start_date [, month_to_add ] )返回包含指定日期的月份的最后一天(具有可选偏移量)。返回类型为 start_date 参数类型或 date 数据类型。Deterministic
SWITCHOFFSETSWITCHOFFSET (DATETIMEOFFSET , time_zone)SWITCHOFFSET 更改 DATETIMEOFFSET 值的时区偏移量并保留 UTC 值。具有 DATETIMEOFFSET 小数精度的 datetimeoffsetDeterministic
TODATETIMEOFFSETTODATETIMEOFFSET (expression , time_zone)TODATETIMEOFFSET 将 datetime2 值转换为 datetimeoffset 值。 TODATETIMEOFFSET 针对指定 time_zone 解释本地时间的 datetime2 值。具有 datetime 参数小数精度的 datetimeoffsetDeterministic

设置或返回会话格式函数的函数

函数语法返回值返回数据类型确定性
@@DATEFIRST@@DATEFIRST返回对会话进行 SET DATEFIRST 操作所得结果的当前值。tinyint不具有确定性
SET DATEFIRST设置 DATEFIRST { number@@ }将一周的第一天设置为从 1 到 7 的一个数字。不适用不适用
SET DATEFORMAT设置 DATEFORMAT { format@@ }设置用于输入 datetime 或 smalldatetime 数据的日期各部分(月/日/年)的顺序。不适用不适用
@@LANGUAGE@@LANGUAGE返回当前所用语言的名称。 @@LANGUAGE 不是日期或时间函数。 但是,语言设置会影响日期函数的输出。不适用不适用
SET LANGUAGE设置语言 {[N] "language"language_var }设置会话和系统消息的语言环境。 SET LANGUAGE 不是日期或时间函数。 但是,语言设置会影响日期函数的输出。不适用不适用
sp_helplanguagesp_helplanguage [[ @language = ] "language" ]返回有关所有支持语言的日期格式的信息。 sp_helplanguage 不是日期或时间存储过程。 但是,语言设置会影响日期函数的输出。不适用不适用

用来验证日期和时间值的函数

函数语法返回值返回数据类型确定性
ISDATEISDATE ( expression )确定 datetime 或 smalldatetime 输入表达式是否为有效的日期或时间值。int在指定了 CONVERT 样式参数且样式不等于 0、100、9 或 109 时,ISDATE 只有在与 CONVERT 函数一起使用时才是确定的。

日期和时间相关主题

主题说明
FORMAT返回以指定的格式和可选的区域性格式化的值。 使用 FORMAT 函数将日期/时间和数字值格式化为识别区域设置的字符串。
CAST 和 CONVERT (Transact-SQL)提供有关在日期和时间值与字符串文字及其他日期和时间格式之间进行相互转换的信息。
编写国际化 Transact-SQL 语句提供一些指导原则,用于将使用 SQL transact-sql 语句的数据库和数据库应用程序从一种语言迁移到另一种语言,或支持多种语言。
ODBC 标量函数 (Transact-SQL)提供有关可在 SQL transact-sql 语句中使用的 ODBC 标量函数的信息。 这包括 ODBC 日期和时间函数。
AT TIME ZONE (Transact-SQL)提供时区转换。
  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拼命小孩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值