gpt4 book ai didi

javascript - 如何使用 XS 从 HANA 数据库返回多行?

转载 作者:行者123 更新时间:2023-11-28 19:04:35 24 4
gpt4 key购买 nike

我正在尝试将数据库表中的所有数据检索到 json 对象中,如下所示:

function getTableData()
{
var vals = {};
var data = [];
try {
var dbCon = $.db.getConnection();

var query = 'SELECT * FROM SAPPRD.ZUSERDATATAB';
var pstmt = dbCon.prepareStatement(query);
var rs = {};
rs = pstmt.executeQuery();

while (rs.next()) {
vals.team = rs.getString(1);
vals.fname = rs.getString(3);
vals.lname = rs.getString(2);
data.push(vals);
$.response.status = $.net.http.OK;
}

$.response.setBody(JSON.stringify(data));
// $.response.contentType = contentType;
// $.response.headers.set('Content-Disposition', 'filename=' + filename);
} catch (e) {
$.response.setBody('errors: ' + e.message);
}
}

查询仅部分有效,因为在数据中我得到行数 x 最后一行内容,如下所示:

[{"team":"I313766","fname":"0","lname":"LEGOWSKI"},  
{"team":"I313766","fname":"0","lname":"LEGOWSKI"},
etc. etc.]

如何让它检索所有数据而不是多次检索一行数据?

最佳答案

好的,我找到解决方案了。将声明数组 vals 的单行移动到 while 语句中解决了问题 - 数组 vals 每次都被初始化为空数组,因此允许正确地 .push 每一行,而不是多次将最后一行从数据库表推送到数据中。感谢所有花时间尝试回答的人。

function getTableData()
{

var data = [];
try {
var dbCon = $.db.getConnection();

var query = 'SELECT * FROM SAPPRD.ZUSERDATATAB';
var pstmt = dbCon.prepareStatement(query);
var rs = pstmt.executeQuery();

while (rs.next()) {
var vals = {}; // this is the moved line of code...
vals.team = rs.getString(1);
vals.fname = rs.getString(3);
vals.lname = rs.getString(2);
data.push(vals);
$.response.status = $.net.http.OK;
}

$.response.setBody(JSON.stringify(data));
// $.response.contentType = contentType;
// $.response.headers.set('Content-Disposition', 'filename=' + filename);

} catch (e) {
$.response.setBody('errors: ' + e.message);
}
}

上面的解决方案以防万一将来有人需要它。

关于javascript - 如何使用 XS 从 HANA 数据库返回多行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31939579/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com