封装数据结果集

原理就是用Map存放单条数据然后放到List里

用起来可以这样调用  List list = rs.selectRS(sqlStr);

for(int i=0;i<list.size;i++)
{
    ((Map)list.get(i)).get("username");
}
这样的话就不用每次在写数据库连接了,而且有比较复杂的页面格式输出就可以通过对 i 的控制来实现了

下面是具体实现类可以结合struts,webwork2的标签来用,我已经测试过了没问题
我也看到一些人是自己写类来代替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();//取数据库的列名  我觉得名比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;
 }

}

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值