首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将SQL查询添加到JSON有效负载

将SQL查询添加到JSON有效负载
EN

Stack Overflow用户
提问于 2020-12-26 06:47:21
回答 1查看 160关注 0票数 0

我需要以JSON格式发送SQL查询到REST API,它适用于简单的查询,但我正在尝试使用带有in操作符的WHERE子句。如果我硬编码值,它在Postman中是有效的,但当我将输入数组传递给in操作符时,它似乎没有像预期的那样工作。

代码语言:javascript
复制
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));

这是输出:

代码语言:javascript
复制
{"Script":"SELECT ID, NAME, FQDN FROM SERVER WHERE Name IN (Server-1,Server-2)"}

这是预期的输出:如果在传递数组时出现任何错误,任何人都可以提供帮助。

代码语言:javascript
复制
{"Script":"SELECT ID, NAME, FQDN FROM SERVER WHERE Name IN ('Server-1','Server-2')"}
EN

回答 1

Stack Overflow用户

发布于 2020-12-26 06:59:12

可以使用Array.map对数组中每个元素的单引号进行转义

代码语言:javascript
复制
var serversEscaped = servers.map(function(el) { return '\'' + el + '\''; });

然后使用Array.join生成一个带有逗号的字符串:

代码语言:javascript
复制
var query = serversEscaped.join(', ');

下面是你的整个代码的样子:

代码语言:javascript
复制
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));
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65452371

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档