0

我正在尝试将 db 表中的所有数据检索到 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.]

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

4

2 回答 2

2

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

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);
    }
}

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

于 2015-08-12T09:37:31.407 回答
1

这是 XSJS(服务器端 JS)而不是 SAPUI5。DB 的读取与 Java 中的 JDBC 框架读取 DB 表非常相似,结果集集合将包含数据,您可以遍历它们并将它们移动到本地对象。在 execute_query 期间只有对数据库的调用,而 rs.next() 只是一个读取每一行的循环。

于 2015-08-11T17:10:15.003 回答