转换动态偏移量和日期时间时出错

时间:2017-04-03 06:16:57

标签: sql sql-server datetimeoffset

我有一个offset和datetime的动态参数。

转换日期时我遇到了问题。

Declare @STR NVARCHAR (MAX)
Declare @offset nvarchar = '+05:00'
Declare @paramrequest date = '2017-03-30'

SET @STR = 'select .... where '
+ CONVERT(DATE, SWITCHOFFSET(CONVERT(DATETIMEOFFSET, + 'REQUESTDATETIME'), @offset )) + ' >=' + CAST(@paramrequest AS DATE);

EXECUTE (@STR)

当我运行脚本时,它会让我犯这个错误。如何修复此错误?

  

从字符串转换日期和/或时间时转换失败。

1 个答案:

答案 0 :(得分:0)

您需要正确构建字符串。像这样使用CONCAT

SET @STR = CONCAT('select .... where ',
  'CONVERT(DATE, SWITCHOFFSET(CONVERT(DATETIMEOFFSET,', 
  'REQUESTDATETIME),''',
  @offset,''' )) >= ''', 
 CAST(@paramrequest AS DATE), '''')