0

我对 Java MyBatis 比较陌生。我在 MyBatis 中遇到了 SQL Builder 类。但是,我不明白如何处理 SELECT SQL 查询的结果,尤其是在使用 SQL Builder 时列在每种情况下都不同的情况下。有没有一个例子可以帮助我理解如何写这个?

通常,我使用带有 ResultMap 的 Mapper XML 文件来检索 SQL 语句的输出。

4

1 回答 1

0

我想出了让它工作的方法。我不确定这是否是正确的方法。

在 XML 我做了以下条目

<select id="readSignals" resultType="map">
  ${query}
</select>

${query} 是从 QueryBuilder 类传递的,resultType 设置为“map”。这会导致 myBatis 返回一个 List>,其中列表中的每个 Map 都是一行。String 包含列名,Object 包含数据。

我使用以下代码将 List> 转换为 JSON。

public static JSONObject convertToJSON(List<Map<String, Object>> queryData) {
  JSONObject queryJSONOutput = new JSONObject();
  JSONArray outputArray = new JSONArray();
  queryData.stream().forEach(d -> {
    JSONObject jsonObject = new JSONObject();
    for (String key: d.keySet()) {
      jsonObject.put(key, d.get(key));
    }
    outputArray.put(jsonObject);
  });
  queryJSONOutput.put("data", outputArray);
  return queryJSONOutput;
}
于 2017-10-03T10:35:10.197 回答