SQL-SERVER 日期格式

来源:互联网 发布:final java 参数 编辑:程序博客网 时间:2024/06/14 05:52
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',@StringDateCOLLATESQL_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))前一月,后一月反之
0 0
原创粉丝点击