首页 > 数据库 > mysql教程 > 在 Java 中将 ResultSet 转换为 JSON 最有效的方法是什么?

在 Java 中将 ResultSet 转换为 JSON 最有效的方法是什么?

Barbara Streisand
发布: 2025-01-04 08:40:34
原创
989 人浏览过

What's the Most Efficient Way to Convert a ResultSet to JSON in Java?

ResultSet 到 JSON 的最高效转换?

以下代码使用 JSON 数组和对象将结果集转换为 JSON 字符串:

import org.json.JSONArray;
import org.json.JSONObject;
import org.json.JSONException;

import java.sql.SQLException;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;

public class ResultSetConverter {
  public static JSONArray convert( ResultSet rs )
    throws SQLException, JSONException
  {
    JSONArray json = new JSONArray();
    ResultSetMetaData rsmd = rs.getMetaData();

    while(rs.next()) {
      int numColumns = rsmd.getColumnCount();
      JSONObject obj = new JSONObject();

      for (int i=1; i<numColumns+1; i++) {
        String column_name = rsmd.getColumnName(i);

        // Determine the SQL data type of the column
        switch(rsmd.getColumnType(i)) {
          case java.sql.Types.ARRAY:
            obj.put(column_name, rs.getArray(column_name));
            break;
          case java.sql.Types.BIGINT:
            obj.put(column_name, rs.getInt(column_name));
            break;
          case java.sql.Types.BOOLEAN:
            obj.put(column_name, rs.getBoolean(column_name));
            break;
          case java.sql.Types.BLOB:
            obj.put(column_name, rs.getBlob(column_name));
            break;
          case java.sql.Types.DOUBLE:
            obj.put(column_name, rs.getDouble(column_name));
            break;
          case java.sql.Types.FLOAT:
            obj.put(column_name, rs.getFloat(column_name));
            break;
          case java.sql.Types.INTEGER:
            obj.put(column_name, rs.getInt(column_name));
            break;
          case java.sql.Types.NVARCHAR:
            obj.put(column_name, rs.getNString(column_name));
            break;
          case java.sql.Types.VARCHAR:
            obj.put(column_name, rs.getString(column_name));
            break;
          case java.sql.Types.TINYINT:
            obj.put(column_name, rs.getInt(column_name));
            break;
          case java.sql.Types.SMALLINT:
            obj.put(column_name, rs.getInt(column_name));
            break;
          case java.sql.Types.DATE:
            obj.put(column_name, rs.getDate(column_name));
            break;
          case java.sql.Types.TIMESTAMP:
            obj.put(column_name, rs.getTimestamp(column_name));
            break;
          default:
            obj.put(column_name, rs.getObject(column_name));
            break;
        }
      }

      json.put(obj);
    }

    return json;
  }
}
登录后复制

替代方案解决方案:

另一种方法可能更简单且更节省内存,直接使用 getObject() 方法:

JSONArray json = new JSONArray();
ResultSetMetaData rsmd = rs.getMetaData();
while(rs.next()) {
  int numColumns = rsmd.getColumnCount();
  JSONObject obj = new JSONObject();
  for (int i=1; i<=numColumns; i++) {
    String column_name = rsmd.getColumnName(i);
    obj.put(column_name, rs.getObject(column_name));
  }
  json.put(obj);
}
return json;
登录后复制

以上是在 Java 中将 ResultSet 转换为 JSON 最有效的方法是什么?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板