我正在尝试使用来自 SQL Server 数据库的链接服务器查询 MySQL 数据库。我创建了一个参数化的动态 SQL 查询,当我运行它时,它没有出错,但它返回 0 行。
如果我对参数进行硬编码,它会返回我请求的行的数据。
在参数化查询方面是否有处理 MySQL 的技巧?
此语法返回 0 行:
DECLARE @SQL NVARCHAR(MAX),
@Params VARCHAR(MAX)
SET @SQL = N'SELECT * FROM OPENQUERY(MYSQL, ''SELECT LoanNumber
FROM plms.vw__bid_dd_overlay
WHERE LoanNumber IN (@MyParams);'')'
SET @Params = '1000001289,1000001294,1000001296,1000001303,1000001304,1000001306,1000001308';
EXEC sp_executesql @SQL, N'@MyParams VARCHAR(MAX)', @Params
返回 7:
DECLARE @SQL NVARCHAR(MAX)
SET @SQL = N'SELECT * FROM OPENQUERY(MYSQL, ''SELECT LoanNumber
FROM plms.vw__bid_dd_overlay
WHERE LoanNumber IN (1000001289,1000001294,1000001296,1000001303,1000001304,1000001306,1000001308);'')'
EXEC sp_executesql @SQL;
如有任何帮助,我们将不胜感激。
最佳答案
你需要准备一个语句然后执行它:
SET @Params = '1000001289,1000001294,1000001296,1000001303,1000001304,1000001306,1000001308';
SET @SQL = CONCAT('SELECT LoanNumber
FROM plms.vw__bid_dd_overlay
WHERE LoanNumber IN (' , @MyParams , ' );';
PREPARE statement FROM @SQL;
EXECUTE statement;
关于mysql - 使用链接服务器将参数化动态查询从 SQL Server 传递到 MySQL 数据库时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17532934/