我毫不怀疑我错过了一分钟,但我还是不知道这是什么。以下是查询:
DECLARE @START DATE, @END DATE, @MySQL VARCHAR(MAX)
SELECT @START = '12/1/2020'
SELECT @END = '12/10/2020'
SET @MySQL =
'SELECT * FROM OPENQUERY ([SERVERNAME], ''SELECT * FROM TABLE (NOLOCK) WHERE InitiatedDate BETWEEN ' + @Start + ' AND ' + @End + ')'
EXEC (@MySQL)我知道这个错误:
添加运算符中的数据类型varchar和date不兼容。
我用类似的查询测试了这个级联方法,它成功了,没有问题:
SET @MySQL =
'SELECT * FROM OPENQUERY ([SERVER], ''SELECT top ' + @X + ' * FROM TABLE'')'
EXEC (@MySQL)发布于 2020-12-16 07:39:34
您的第二个示例可能正在工作,因为@X是VARCHAR数据类型。
在您的主要示例中,@START和@END被定义为日期数据类型,因此逻辑上不能将它们附加到VARCHAR数据类型中,就像添加6和‘6’不会导致12或‘66’的结果一样。
您需要使用转换函数将日期更改为日期的字符串表示形式。请小心使用format选项以格式获取字符串,然后该格式可自动转换回查询运行时的日期。
'SELECT * FROM OPENQUERY ([SERVERNAME], ''SELECT * FROM TABLE (NOLOCK) WHERE InitiatedDate BETWEEN ''' + CONVERT(varchar(10), @Start, 101) + ''' AND ''' + CONVERT(varchar(10), @End, 101) + ''')'
https://stackoverflow.com/questions/65311573
复制相似问题