Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/61.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 如何使用JDBC以对象数组的形式获取整行_Java_Mysql_Sql_Jdbc_Fetch - Fatal编程技术网

Java 如何使用JDBC以对象数组的形式获取整行

Java 如何使用JDBC以对象数组的形式获取整行,java,mysql,sql,jdbc,fetch,Java,Mysql,Sql,Jdbc,Fetch,我必须为通过JDBC访问MySQL的类创建一个“查询”方法 该方法的输入参数是一个完整的SQL命令(包含值),因此我不知道要提取的列的名称 有些列是字符串,有些是整数,等等 该方法需要返回类型为ArrayList 其中每个HashMap为1行,ArrayList包含结果的所有行 我正在考虑使用ResultSet.getMetaData().getColumnCount()获取列数,然后从当前行中逐单元格提取,但这是唯一的解决方案吗?有更好的吗?我这里有示例代码,以防有人需要。(“Con”在代码中

我必须为通过JDBC访问MySQL的类创建一个“查询”方法

该方法的输入参数是一个完整的SQL命令(包含值),因此我不知道要提取的列的名称

有些列是字符串,有些是整数,等等

该方法需要返回类型为
ArrayList
其中每个HashMap为1行,ArrayList包含结果的所有行


我正在考虑使用
ResultSet.getMetaData().getColumnCount()
获取列数,然后从当前行中逐单元格提取,但这是唯一的解决方案吗?有更好的吗?

我这里有示例代码,以防有人需要。(“Con”在代码中是标准的JDBC连接)

//查询完整的sql命令
公共静态数组列表
rawQuery(字符串完整命令){
试一试{
//创建语句
语句stm=null;
stm=con.createStatement();
//质疑
ResultSet result=null;
布尔returningRows=stm.execute(fullCommand);
如果(返回行)
结果=stm.getResultSet();
其他的
返回新的ArrayList();
//获取元数据
结果元数据元数据=null;
meta=result.getMetaData();
//获取列名
int colCount=meta.getColumnCount();
ArrayList cols=新的ArrayList();
对于(int index=1;index
//query a full sql command
public static ArrayList<HashMap<String,Object>> 
rawQuery(String fullCommand) {
  try {

    //create statement
    Statement stm = null;
    stm = con.createStatement();

    //query
    ResultSet result = null;
    boolean returningRows = stm.execute(fullCommand);
    if (returningRows)
      result = stm.getResultSet();
    else
      return new ArrayList<HashMap<String,Object>>();

    //get metadata
    ResultSetMetaData meta = null;
    meta = result.getMetaData();

    //get column names
    int colCount = meta.getColumnCount();
    ArrayList<String> cols = new ArrayList<String>();
    for (int index=1; index<=Col_Count; index++)
      cols.add(meta.getColumnName(index));

    //fetch out rows
    ArrayList<HashMap<String,Object>> rows = 
    new ArrayList<HashMap<String,Object>>();

    while (result.next()) {
      HashMap<String,Object> row = new HashMap<String,Object>();
      for (String colName:cols) {
        Object val = Result.getObject(colName);
        row.put(colName,val);
      }
      rows.add(row);
    }

    //close statement
    stm.close();

    //pass back rows
    return tows;
  }
  catch (Exception ex) {
    System.out.print(ex.getMessage());
    return new ArrayList<HashMap<String,Object>>();
  }
}//raw_query