我必须为我的类创建一个'query'方法,通过'JDBC。
访问MySQL该方法的输入参数是一个完整的SQL命令(包含值),因此我不知道要提取的列的名称。
有些列是字符串,有些是整数等等。
该方法需要返回类型ArrayList<HashMap<String,Object>>
的值
其中每个HashMap为1行,ArrayList包含结果的所有行。
我正在考虑使用ResultSet.getMetaData().getColumnCount()
来获取列数,然后逐个单元格从当前行中获取,但这是唯一的解决方案吗?还有更好的吗?
答案 0 :(得分:13)
我在这里有示例代码,以防任何人需要它。 (代码中的'Con'是标准JDBC连接)。
//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
答案 1 :(得分:0)
看到Java缺少有用的数据库处理工具并要求您自己动手,真是令人不寒而栗。与其他现代语言更易于访问的设计相去甚远。例如,对于它获得的所有嘲笑,至少在PHP中,您可以执行诸如result.getResults()之类的操作,并获取一个Maps列表,其中每个Map都是一行,其列名为键。它是如此简单,但是在Java中,您需要花费时间来定制自己的代码。这意味着那里有成千上万种不同的db helper方法可以执行完全相同的操作,全部是因为Java不能。