如何从SQL Server 2005日期时间以HH:mm tt
格式获取时间部分
例如
11:25 AM
14:36 PM
一种方法是:
SELECT LTRIM(RIGHT(CONVERT(VARCHAR(20), GETDATE(), 100), 7))
[如果您查看Books Online here,则格式100是具有您想要的格式的时间元素的,这只是从前面剥离日期的情况。
对于SQL Server 2012及更高版本,使用此:
SELECT Format(GetDate(), 'hh:mm tt')
您需要两次转换,一次获得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替换为列名。
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
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
select substring(CONVERT(VARCHAR, getdate(), 114),1,5)
resault:22:05
您需要使用CONVERT
功能:
CONVERT(VARCHAR, yourdatetimefiled, 114) AS [HH:MI(12H)]
select cast(getdate() as time)) [time],
这给您一个实际的日期时间而不是varchar
CAST(LEFT(YOURDATETIME,12) AS SMALLDATETIME) AS YOURNEWDATE
select right(convert(char(20),getdate(),0),7)
虽然没有检查