我需要以JSON格式发送SQL查询到REST API,它适用于简单的查询,但我正在尝试使用带有in操作符的WHERE子句。如果我硬编码值,它在Postman中是有效的,但当我将输入数组传递给in操作符时,它似乎没有像预期的那样工作。
var servers = ['Server-1','Server-2'];
var requestBody = {};
requestBody.Script = 'SELECT ID, NAME, FQDN FROM SERVER WHERE Name IN ('+servers+')';
gs.log("Advanced Request3 Body: "+JSON.stringify(requestBody));这是输出:
{"Script":"SELECT ID, NAME, FQDN FROM SERVER WHERE Name IN (Server-1,Server-2)"}这是预期的输出:如果在传递数组时出现任何错误,任何人都可以提供帮助。
{"Script":"SELECT ID, NAME, FQDN FROM SERVER WHERE Name IN ('Server-1','Server-2')"}发布于 2020-12-26 06:59:12
可以使用Array.map对数组中每个元素的单引号进行转义
var serversEscaped = servers.map(function(el) { return '\'' + el + '\''; });然后使用Array.join生成一个带有逗号的字符串:
var query = serversEscaped.join(', ');下面是你的整个代码的样子:
var servers = ['Server-1','Server-2'];
var requestBody = {};
var serversEscaped = servers.map(function(el) { return '\'' + el + '\''; });
var query = serversEscaped.join(', ');
requestBody.Script = 'SELECT ID, NAME, FQDN FROM SERVER WHERE Name IN ('+ query +');'
console.log(JSON.stringify(requestBody));https://stackoverflow.com/questions/65452371
复制相似问题