我有一个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)
当我运行脚本时,它会让我犯这个错误。如何修复此错误?
从字符串转换日期和/或时间时转换失败。
答案 0 :(得分:0)
您需要正确构建字符串。像这样使用CONCAT
:
SET @STR = CONCAT('select .... where ',
'CONVERT(DATE, SWITCHOFFSET(CONVERT(DATETIMEOFFSET,',
'REQUESTDATETIME),''',
@offset,''' )) >= ''',
CAST(@paramrequest AS DATE), '''')