SQL-SERVER 日期格式

1.SELECT convert ( varchar , getdate(),100) -- mon dd yyyy hh:mmAM (orPM)
  
-- Oct 2 200811:01AM 
SELECT convert ( varchar , getdate(),101) -- mm/dd/yyyy -10/02/2008 
SELECT convert ( varchar , getdate(),102) -- yyyy.mm.dd --2008.10.02 
SELECT convert ( varchar , getdate(),103) -- dd/mm/yyyy
SELECT convert ( varchar , getdate(),104) -- dd.mm.yyyy
SELECT convert ( varchar , getdate(),105) -- dd-mm-yyyy
SELECT convert ( varchar , getdate(),106) -- dd mon yyyy
SELECT convert ( varchar , getdate(),107) -- mon dd, yyyy
SELECT convert ( varchar , getdate(),108) -- hh:mm:ss
SELECT convert ( varchar , getdate(),109) -- mon dd yyyyhh:mm:ss:mmmAM (or PM)
-- Oct 2 200811:02:44:013AM 
SELECT convert ( varchar , getdate(),110) -- mm-dd-yyyy
SELECT convert ( varchar , getdate(),111) -- yyyy/mm/dd
SELECT convert ( varchar , getdate(),112) -- yyyymmdd
SELECT convert ( varchar , getdate(),113) -- dd mon yyyyhh:mm:ss:mmm
-- 02 Oct 200811:02:07:577 
SELECT convert ( varchar , getdate(),114) --hh:mm:ss:mmm(24h)
SELECT convert ( varchar , getdate(),120) -- yyyy-mm-ddhh:mm:ss(24h)
SELECT convert ( varchar , getdate(),121) -- yyyy-mm-ddhh:mm:ss.mmm
SELECT convert ( varchar , getdate(),126) --yyyy-mm-ddThh:mm:ss.mmm
-- 2008-10-02T10:52:47.513
-- 利用字符串函数创建不同的日期格式
SELECT replace ( convert ( varchar , getdate(),111), '/' , '' ) -- yyyy mm dd
SELECT convert ( varchar (7), getdate(),126) -- yyyy-mm
SELECT right ( convert ( varchar , getdate(),106), 8) -- mon yyyy
go
--通用的日期转换函数CREATE FUNCTION dbo.fnFormatDate(@Datetime DATETIME, @FormatMask VARCHAR(32))RETURNSVARCHAR(32)AS
BEGIN
DECLARE @StringDate VARCHAR (32)
SET @StringDate =@FormatMask
IF(CHARINDEX ( 'YYYY' ,@StringDate)> 0)
SET @StringDate= REPLACE (@StringDate, 'YYYY' ,DATENAME(YY,@Datetime))
IF(CHARINDEX ( 'YY' ,@StringDate) > 0)
SET @StringDate= REPLACE (@StringDate, 'YY' , RIGHT (DATENAME(YY,@Datetime),2))
IF(CHARINDEX ( 'Month' ,@StringDate)> 0)
SET @StringDate= REPLACE (@StringDate, 'Month' ,DATENAME(MM,@Datetime))
IF(CHARINDEX ( 'MON' ,@StringDate COLLATE SQL_Latin1_General_CP1_CS_AS)>0)
SET @StringDate= REPLACE (@StringDate, 'MON' , LEFT ( UPPER (DATENAME(MM,@Datetime)),3))
IF(CHARINDEX ( 'Mon' ,@StringDate) >0)
SET @StringDate= REPLACE (@StringDate, 'Mon' , LEFT (DATENAME(MM,@Datetime),3))
IF(CHARINDEX ( 'MM' ,@StringDate) > 0)
SET @StringDate= REPLACE (@StringDate, 'MM' , RIGHT ( '0' + CONVERT ( VARCHAR ,DATEPART(MM,@Datetime)),2))
IF(CHARINDEX ( 'M' ,@StringDate) > 0)
SET @StringDate= REPLACE (@StringDate, 'M' , CONVERT ( VARCHAR ,DATEPART(MM,@Datetime)))
IF(CHARINDEX ( 'DD' ,@StringDate) > 0)
SET @StringDate= REPLACE (@StringDate, 'DD' , right ( '0' +DATENAME(DD,@Datetime),2))
IF(CHARINDEX ( 'D' ,@StringDate) > 0)
SET @StringDate= REPLACE (@StringDate, 'D' ,DATENAME(DD,@Datetime)) 
RETURN @StringDate
 
END
GO
 
 
2.通过dateadd函数来制定时间间隔
selectdateadd(year,-1,convert(varchar, getdate(),101))前一年,后一年反之
select dateadd(month,-1,convert(varchar, getdate(),101))前一月,后一月反之
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值