sql服务器系统时间格式,SQL Server 日期格式和日期操做

sql服务器系统时间格式,SQL Server 日期格式和日期操做SQLServer发展至今,关于日期的格式的控制方法,有传统的方法,好比CONVERT(),也有比较便利的新方法,好比FORMAT();一样,关于日期的操做函数,也分为传统方法:DATEADD()等,也有便利的新方法:EOMonth()等。sql一,日期的格式化格式化是指把日期类型(Date)、日期和时间类型转化为字符类型,一般使用CONVERT()和FORMAT()函数。express1,传统…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

SQL Server发展至今,关于日期的格式的控制方法,有传统的方法,好比CONVERT(),也有比较便利的新方法,好比FORMAT();一样,关于日期的操做函数,也分为传统方法:DATEADD()等,也有便利的新方法:EOMonth()等。sql

一,日期的格式化

格式化是指把日期类型(Date)、日期和时间类型转化为字符类型,一般使用CONVERT()和FORMAT()函数。express

1,传统的CONVERT()函数

SQL Server控制日期的的显示格式,一般使用CONVERT()函数,经过控制style参数来控制日期显示的格式,可是,style不少,不利于记忆。spa

CONVERT ( data_type [( length )] , expression [, style] )

符合东方人阅读习惯的style及其显示格式以下:code

101: mm/dd/yyyy

110: mm-dd-yyyy

111: yyyy/mm/dd

112: yyyymmdd

120: yyyy-mm-dd hh:mm:ss

121: yyyy-mm-dd hh:mm:sssssss

CONVERT()函数的style是数字,记忆起来比较困难,而且只能按照系统定义的格式来显示,不够灵活。SQL Server提供更为灵活的转换函数FORMAT()。orm

2,便利的FORMAT()函数server

FORMAT()函数,能够方便和灵活地控制数值、日期和时间类型的显示格式,一般状况下,FORMAT()函数主要用于格式化显示date/time类型和数值类型,参数format用于指定显示的格式,给予用户对格式更自由地控制,culture参数是可选的,用于指定显示的语言,该函数返回值的数据类型是NVARCHAR,若是格式转换失败,该函数返回NULL:blog

FORMAT ( value, format [, culture] )

参数format使用#表示一个数值,参数 format 使用如下占位符来表示日期/时间的格式:ci

yyyy、MM、dd:表示年、月、日

hh:mm:ss fffffff:表示时、分、秒、毫秒

使用“/”,“-”等做为链接各个部分(part)的分割符号

(1)把date/time格式化rem

在format参数中指定日期/时间显示的格式,以特定的格式: “yyyy:MMdd hh:mm:ss fffffff” 显式日期/时间,例如:

select format(SYSDATETIME(),’yyyy-MM-dd hh:mm:ss fffffff’)

27a99fe46ce52d0a32219cc51c1cfd89.png

(2)转换数值类型

在参数format中使用#表明一个数字,使用相应的链接符,拼接成数字的格式字符,例如:

FORMAT(123456789,’###-##-####’) AS ‘Custom Number Result

60edfc04de9e7fd782b6171d0b1e6322.png

二,日期和时间的结构

经常使用的日期的构成(datepart)是:year、month、day、hour、minute、second、ns、TZoffset(简写为 tz)

DATEPART ( datepart, date )YEAR( date )MONTH( date )DAY ( date )

在实际的产品环境中,周、季度等都颇有用途:

quarter:季度,取值范围是 一、二、三、4

week:周在年中的序数,取值范围是 1 – 53

dayofyear:天在年中的序数,取值范围是 1 – 366

weekday:天在一周中的序数,取值范围是 1 – 7

DATEPART()返回的datepart是int类型,若是想要返回字符类型,可使用DATENAME()函数:

DATENAME ( datepart , date )

经过datepart来构造日期,经常使用的函数有:

DATEFROMPARTS ( year, month, day)

DATETIME2FROMPARTS (year, month, day, hour, minute, seconds, fractions, precision)

DATETIMEOFFSETFROMPARTS (year, month, day, hour, minute, seconds, fractions, hour_offset, minute_offset, precision)

TIMEFROMPARTS ( hour, minute, seconds, fractions,precision )

参数precision 是指小数秒的精度,指的是DateTime2(n)、DateTimeOffset(n),Time(n)中的n值,表示以多少位小数表示1s。

三,日期操做

日期函数:EOMonth、Format、DateAdd、DateDiff、SwitchOffset

1,月份的最后一天

函数 EOMonth() 返回指定日期的最后一天

EOMONTH ( start_date [, month_to_add] )

参数注释:

start_date: 有两种输入方式,可以转换为Date的字符串类型 和 date 数据类型

month_to_add: 是int 类型,可以为正整数,负整数和0,默认值是0,若是省略,那么使用默认值0。

例如,查看当前月的最后一天、下一个月的最后一天、上一个月的最后一天:

declare @datedateset @date=getdate()select EOMONTH(@date) asCurrentMonth_EndDay,

EOMONTH(@date,1) asNextMonth_EndDay,

EOMONTH(@date,-1) as LastMonth_EndDay

2,月份的第一天

使用DateFromParts() 函数,可以从3个正整数(year,month,day)中获取date 类型,只须要将day 参数设置1,就能获取月份的第一天的日期。

declare @datedateset @date=getdate()select DATEFROMPARTS(year(@date),month(@date),1)

也可使用Format() 函数, 以字符串形式返回月份的第一天,例如,获取当前月份的第一天:

FORMAT(GETDATE(),’yyyyMM01′)

3,切换时区

把DateTimeOffset类型的数据切换到指定的时区,在转换过程当中,UTC时间是固定的,依据固定的UTC时间,切换到特定时区的本地时间:

SWITCHOFFSET ( DATETIMEOFFSET, time_zone )

参数注释:

DATETIMEOFFSET:DateTimeOffset(n)类型的变量

time_zone:指定的目标时区数据,格式是  [+|-] hh:mm

使用SwitchOffset()函数把DateTimeOffset的时区偏移(Offset)切换到指定的时区中,例如,把本地时间的时区东八区切换到东七区:

DECLARE @remoteDATETIMEOFFSETDECLARE @localDATETIMEOFFSETSET @local =SYSDATETIMEOFFSET()SET @remote = SWITCHOFFSET (@local, ‘+07:00’)SELECT @remote AS remote_time,@local AS local_time

39170a5b2227d2309fea57be5cdd00f5.png

能够看到,东7区的时间比东8区的时间晚一个小时。

4,当前日期是周几

在SQL Server中,经过DataFirst选项设置一周的第一天,序数是从1到7,表示一周的7天。

SET DATEFIRST { number | @number_var }

(1)能够经过@@datefirst来获取设置的值

set DATEFIRST 1

select @@datefirst

(2)使用函数datepart函数获取当天是周几

set DATEFIRST 1

select datepart(WEEKDAY,getutcdate())set DATEFIRST 2

–select @@datefirst

select datepart(WEEKDAY,getutcdate())

因为设置不一样的DateFirst,会致使datepart返回不一样的数值,因此必须借助@@DateFirst

set DATEFIRST 2

select Datepart(weekday, getdate()+@@datefirst – 1)set DATEFIRST 1

select Datepart(weekday, getdate()+@@datefirst – 1)

4,使用DateName获取WeekDay的名字

WeekDay的名字跟系统的语言设置有管,跟DateFirst的设置没有关系

(1) 查看当前的语言设置

select @@language

(2) 查看系统支持的语言

select alias,name, *

from sys.syslanguages

(3) 设置语言

set LANGUAGE ‘Simplified Chinese’

set LANGUAGE ‘us_english’

(4) 使用DateName获取WeekDay的名字

set LANGUAGE ‘Simplified Chinese’

select DATENAME(WEEKDAY,getutcdate())set LANGUAGE ‘us_english’

select DATENAME(WEEKDAY,getutcdate())

参考文档:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/180107.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 手把手教你学dsp_大咖问答第13期:如何掌握DSP设计?顾卫钢博士在线为你解答…「建议收藏」

    手把手教你学dsp_大咖问答第13期:如何掌握DSP设计?顾卫钢博士在线为你解答…「建议收藏」本期邀请到了顾卫钢,参加电路城论坛第十三期大咖问答(8月4日-8月16日),本期将由顾卫钢为大家解答关于DSP设计方面的各种问题。大咖简介:顾卫钢,东南大学电气工程学院博士国内知名嵌入式培训专家,嵌入式产品技术顾问,2019年荣获TI大学计划卓越贡献奖。拥有近十年产品研发经验,近年来带领团队研发了具有代码自动生成功能、基于模型设计的实时数字控制器RTU-BOX、积木式电力电子功率组件等…

  • 我的IDEA常用快捷键记录

    我的IDEA常用快捷键记录用了这么久的IDEA了,感觉就这些快捷键最好用,一起分享吧。快捷键组合实现效果psvm+Tab键publicstaticvoidmain(String[]args)sout+Tab键System.out.println()Ctrl+X删除当前行Ctrl+D复制当前行Alt+Insert(或右键Generate)生成代码(如get,set方法,构造函数等)Ctrl+Alt+T生成trycatch(或者Alt+ente

  • shuffleNet_shuffer

    shuffleNet_shuffer目录分组卷积分组卷积的矛盾——计算量分组卷积的矛盾——特征通信channelshuffleShuffleNetV1ShuffleNet基本单元ShuffleNet网络结构对比实验ShuffleNetV2设计理念网络结构对比实验分组卷积Groupconvolution是将输入层的不同特征图进行分组,然后采用不同的卷积核再对各个组进行卷积,这样会降低卷积的计算量。因为一般的卷积都是在所有的输入特征图上做卷积,可以说是全通道卷积,这是一种通道密集连.

  • String字符串转JSONArray

    String字符串转JSONArrayStringmarString=request.getParameter(“params”);JSONArrayjsonArray=JSONArray.fromObject(marString);if(jsonArray!=null&&jsonArray.size()>0){for(inti=0;i

  • CLion2022.01.13激活码(JetBrains全家桶)

    (CLion2022.01.13激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

  • [导入]sqlserver 判断临时表是否存在语句.

    [导入]sqlserver 判断临时表是否存在语句.

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号