50

我有这种日期格式:2011-09-28 18:01:00(在 varchar 中),我想将其转换为日期时间,更改为 28-09-2011 18:01:00 这种格式。我该怎么做?

4

9 回答 9

82
SELECT CONVERT(Datetime, '2011-09-28 18:01:00', 120) -- to convert it to Datetime

SELECT CONVERT( VARCHAR(30), @date ,105) -- italian format [28-09-2011 18:01:00]
+ ' ' + SELECT CONVERT( VARCHAR(30), @date ,108 ) -- full date [with time/minutes/sec]
于 2012-04-20T13:28:59.510 回答
12

像这样

DECLARE @date DATETIME
SET @date = '2011-09-28 18:01:00'
select convert(varchar, @date,105) + ' ' + convert(varchar, @date,108)
于 2012-04-20T13:26:21.227 回答
10

网站显示了几个格式选项。

例子:

SELECT CONVERT(VARCHAR(10), GETDATE(), 105) 
于 2012-04-20T13:26:55.190 回答
7

您可以拥有所有不同的样式datetime conversion

https://www.w3schools.com/sql/func_sqlserver_convert.asp

这具有值范围:-

CONVERT(data_type(length),expression,style)

对于样式值,
请选择您需要的任何人,例如我需要 106。

于 2015-02-02T05:49:58.943 回答
4

试试下面

select Convert(Varchar(50),yourcolumn,103) as Converted_Date from yourtbl
于 2016-04-21T15:21:16.317 回答
3

您可以这样做,但它将其保留为 varchar

declare @s varchar(50)

set @s = '2011-09-28 18:01:00'

select convert(varchar, cast(@s as datetime), 105) + RIGHT(@s, 9)

或者

select convert(varchar(20), @s, 105)
于 2012-04-20T13:26:28.367 回答
3

如前所述,日期时间没有格式/字符串表示格式。

您可以使用一些格式更改字符串输出。

要将您的字符串转换为日期时间:

declare @date nvarchar(25) 
set @date = '2011-09-28 18:01:00' 

-- To datetime datatype
SELECT CONVERT(datetime, @date)

给出:

-----------------------
2011-09-28 18:01:00.000

(1 row(s) affected)

要将其转换为您想要的字符串:

-- To VARCHAR of your desired format
SELECT CONVERT(VARCHAR(10), CONVERT(datetime, @date), 105) +' '+ CONVERT(VARCHAR(8), CONVERT(datetime, @date), 108)

给出:

-------------------
28-09-2011 18:01:00

(1 row(s) affected)
于 2012-04-20T13:28:04.467 回答
3
SELECT CONVERT(VARCHAR(10), GETDATE(), 105) + ' ' + CONVERT(VARCHAR(10), GETDATE(), 108)
于 2012-04-20T13:31:16.767 回答
0

我厌倦了所有不同的转换谷歌搜索,最终得到了这个在新变体上扩展的实用功能。

CREATE FUNCTION [dbo].[ParseDatetime] (
    @INPUT nvarchar(255),
    @FORMAT nvarchar(255)
)
RETURNS datetime

AS 
BEGIN 


DECLARE @TimePart NVARCHAR(255)
DECLARE @DatePart NVARCHAR(255)
DECLARE @DayPart NVARCHAR(255)
DECLARE @ExDayPart NVARCHAR(255)
DECLARE @MonthPart NVARCHAR(255)
DECLARE @YearPart NVARCHAR(255)
DECLARE @Date DATETIME
--DECLARE @INPUTSTRING NVARCHAR(255)
--SET @INPUTSTRING = '20-10-2019 00:00:00'

--SET @FORMAT = 'D-M-YYYY HH:MM:SS'
IF(@FORMAT = 'D-M-YYYY HH:MM:SS')
BEGIN
    SET @TimePart = RIGHT(@INPUT,LEN(@INPUT)-CHARINDEX(' ',@INPUT))
    SET @DatePart = LEFT(@INPUT,CHARINDEX(' ',@INPUT))
    SET @DayPart = LEFT(@DatePart,charindex('-',@DatePart)-1)
    SET @ExDayPart = RIGHT(@DatePart,LEN(@DatePart)-charindex('-',@DatePart)+1)
    SET @MonthPart = left(@ExDayPart ,charindex('-',@ExDayPart )-1)
    SET @YearPart = right(@ExDayPart ,LEN(@ExDayPart )-charindex('-',@ExDayPart )+1)
    SET @Date = DATEFROMPARTS(@YearPart,@MonthPart,@DayPart) 

END

IF(@FORMAT = 'YYYY-MM-DD')
BEGIN
    SET @DayPart = RIGHT(@INPUT,2)
    SET @MonthPart = RIGHT(left(@INPUT,7),2)
    SET @YearPart = LEFT(@INPUT,4)
    SET @Date = DATEFROMPARTS(@YearPart,@MonthPart,@DayPart) 

END

IF(@FORMAT = 'EXCEL_DAYS_SINCE_1900')
BEGIN
--DECLARE @INPUT NVARCHAR(255)
--SET @INPUT = ' 43554' 
    SET @Date = Dateadd(day,CAST(@INPUT AS INT),datefromparts(1900,1,1))
END


RETURN @Date
END
GO

将其用作:

SELECT
[DateAsDate] = dbo.[ParseDateTime]([DateAsString], 'YYYY-MM-DD')
FROM [tablename]
于 2021-06-25T08:39:18.100 回答