原理就是用Map存放單條數(shù)據(jù)然后放到List里
用起來可以這樣調(diào)用 List list = rs.selectRS(sqlStr);
for(int i=0;i<list.size;i++)
{
((Map)list.get(i)).get("username");
}
這樣的話就不用每次在寫數(shù)據(jù)庫連接了,而且有比較復(fù)雜的頁面格式輸出就可以通過對 i 的控制來實(shí)現(xiàn)了
下面是具體實(shí)現(xiàn)類可以結(jié)合struts,webwork2的標(biāo)簽來用,我已經(jīng)測試過了沒問題
我也看到一些人是自己寫類來代替Map來用的
package com;
import conn.DBConnManager;
import java.sql.*;
import java.util.*;
public class ResultGather
{
private String sql;
public ResultGather()
{
}
public ResultGather(String sqlcom)
{
this.sql=sqlcom;
}
public List selectRS(String sqlStr)
{
this.sql = sqlStr;
return selectRS();
}
public List selectRS()
{
List rsall = new ArrayList();
Map rsTree;
DBConnManager conn = null;
Connection con = null;
Statement stmt = null;
ResultSet rs = null;
try{
conn = DBConnManager.getInstance();
con = conn.getConnection("mssql");
stmt = con.createStatement();
rs = stmt.executeQuery(sql);
ResultSetMetaData rsmd = rs.getMetaData();//取數(shù)據(jù)庫的列名 我覺得名比1,2,3..更好用
int numberOfColumns = rsmd.getColumnCount();
while(rs.next())
{
rsTree = new HashMap(numberOfColumns);//注意要new
for(int r=1;r<numberOfColumns+1;r++)
{
rsTree.put(rsmd.getColumnName(r),rs.getObject(r));
}
rsall.add(rsTree);
}
}catch(java.lang.Exception ex){
ex.printStackTrace();
}finally{
try{
if(rs!=null)
rs.close();
if(stmt!=null)
stmt.close();
if(conn!=null)
conn.releaseConnection("mssql",con);
}catch(Exception e){
}
}
return rsall;
}
}
簡單的東西 交流交流