1

我正在尝试拆分 ASA 查询的日期和时间组件,但遇到了一些困难。我确实尝试使用 concat、datepart 和 dateadd 函数来实现这一点,但它出现了查询编译失败错误。关于我做错了什么或实现这一目标的另一种更好方法的任何想法?

ConCat(DatePart(hh,DateAdd(Hour,11,System.Timestamp)),':',DatePart(mm,DateAdd(Hour,11,System.Timestamp))) 作为时间,

谢谢

4

2 回答 2

2

Concat 函数将字符串作为输入,您必须将 datepart() 的输出转换为字符串。下面应该工作。

select 

concat(
    cast( datepart(yy,System.Timestamp) as nvarchar(max)),
    '-',
    cast( datepart(mm,System.Timestamp) as nvarchar(max)),
    '-',
    cast( datepart(dd,System.Timestamp) as nvarchar(max))) [Date],

concat(
    cast( datepart(hh,System.Timestamp) as nvarchar(max)),
    ':',
    cast( datepart(ss,System.Timestamp) as nvarchar(max))) [Time]

into outputStore from inputSource
于 2016-04-05T17:44:12.457 回答
1

您有两种可能的解决方案:

1. 使用类似 T-SQL 的语法

DATEADD(dd, DATEDIFF(dd, '0001-01-01 00:00:00', [TimeStamp]), '0001-01-01 00:00:00')

2.在DateTime builder中使用build

DATETIMEFROMPARTS(DATEPART(year,[TimeStamp]),DATEPART(month,[TimeStamp]),DATEPART(day,[TimeStamp]),00,00,00,00)
于 2017-02-05T03:55:18.163 回答