我想从DateTime列使用SQL查询只得到时间 使用SQL Server 2005和2008 默认的输出:
AttDate
==
2011-02-09 13:09:00
2011-02-09 14:10:00
我想要这样的输出:
AttDate Time
==
2011-02-09 13:09:00 13:09
2011-02-09 14:10:00 14:10
我想从DateTime列使用SQL查询只得到时间 使用SQL Server 2005和2008 默认的输出:
AttDate
==
2011-02-09 13:09:00
2011-02-09 14:10:00
我想要这样的输出:
AttDate Time
==
2011-02-09 13:09:00 13:09
2011-02-09 14:10:00 14:10
当前回答
试试这个:
select convert(nvarchar,CAST(getdate()as time),100)
其他回答
我经常使用这个脚本从DateTime获取时间:
SELECT CONVERT(VARCHAR(9),RIGHT(YOURCOLUMN_DATETIME,9),108) FROM YOURTABLE
SQL Server 2008+有一个“时间”数据类型
SELECT
..., CAST(MyDateTimeCol AS time)
FROM
...
对于旧版本,没有varchar转换
SELECT
..., DATEADD(dd, DATEDIFF(dd, MyDateTimeCol, 0), MyDateTimeCol)
FROM
...
获取服务器日期
SELECT LTRIM(RIGHT(CONVERT(VARCHAR(20), GETDATE(), 100), 7)) FROM TABLENAME WHERE ...
or
如果存储在表中
SELECT LTRIM(RIGHT(CONVERT(VARCHAR(20), datename, 100), 7)) FROM TABLENAME WHERE ...
结果:
11:41AM
要从datetime获取时间,我们可以使用
SELECT CONVERT(VARCHAR(20), GETDATE(), 114)
select substr(to_char('DD/MM/RRRR HH:MM:SS'),11,19) from table_name;
输出:
05:11:26
05:11:24
05:11:24