如何从SQL Server 2005日期时间中以'HH:mm tt'格式获取时间部分

问题描述 投票:18回答:10

如何从SQL Server 2005日期时间以HH:mm tt格式获取时间部分

例如

11:25 AM
14:36 PM
sql tsql sql-server-2005 time
10个回答
26
投票

一种方法是:

SELECT LTRIM(RIGHT(CONVERT(VARCHAR(20), GETDATE(), 100), 7))

[如果您查看Books Online here,则格式100是具有您想要的格式的时间元素的,这只是从前面剥离日期的情况。


0
投票

对于SQL Server 2012及更高版本,使用此:

SELECT Format(GetDate(), 'hh:mm tt')


9
投票

您需要两次转换,一次获得HH:mm时间,一次获得AM / PM。例如:

declare @date datetime
set @date = '20:01'
SELECT CONVERT(VARCHAR(5), @date, 108) + ' ' +
       SUBSTRING(CONVERT(VARCHAR(19), @date, 100),18,2)

此打印:

20:01 PM

在选择查询中,将@date替换为列名。


7
投票

SQL Server 2008

SELECT
CONVERT(TIME,GETDATE()) AS HourMinuteSecond,
CONVERT(DATE,GETDATE(),101) AS DateOnly
GO

结果

HourMinuteSecond: 13:06:56.5770000
DateOnly:         2012-07-26

SQL Server 2000/2005

SELECT
CONVERT(VARCHAR(8),GETDATE(),108) AS HourMinuteSecond,
CONVERT(VARCHAR(8),GETDATE(),101) AS DateOnly
GO

http://blog.sqlauthority.com/2009/08/06/sql-server-get-time-in-hourminute-format-from-a-datetime-get-date-part-only-from-datetime/


2
投票

SQL Server 2008

SELECT
CONVERT(TIME,GETDATE()) AS HourMinuteSecond,
CONVERT(DATE,GETDATE(),101) AS DateOnly
GO

结果:

HourMinuteSecond: 13:06:56.5770000
DateOnly:         2012-07-26

SQL Server 2000/2005

SELECT
CONVERT(VARCHAR(8),GETDATE(),108) AS HourMinuteSecond,
CONVERT(VARCHAR(8),GETDATE(),101) AS DateOnly
GO

2
投票
select substring(CONVERT(VARCHAR, getdate(), 114),1,5)

resault:22:05


1
投票

您需要使用CONVERT功能:

CONVERT(VARCHAR, yourdatetimefiled, 114) AS [HH:MI(12H)]

1
投票
select cast(getdate() as time)) [time],

1
投票

这给您一个实际的日期时间而不是varchar

CAST(LEFT(YOURDATETIME,12) AS SMALLDATETIME) AS YOURNEWDATE

0
投票
select right(convert(char(20),getdate(),0),7)

虽然没有检查

© www.soinside.com 2019 - 2024. All rights reserved.