使用Spring的JdbcTemplate获得任意表的数据集
来源:互联网 发布:微信淘客软件哪个好 编辑:程序博客网 时间:2024/06/01 09:17
因为使用HibernateHql语句需要事先有实体类和Hibernate映射文件,所以查询表数据之前必须有此表对应的实体类,在很多时候这是很不方便的,在这种情况下我们可以考虑使用Spring提供的JdbcTemplate模板类,并通过RowMapper机制实现,主要方式使将查询结果封装为Hashtable,最终获得一个Hashtable的结果集,见下文的JSP和java文件:
实现一个HashtableRowMapper:
package org.openjweb.core.util;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.Hashtable;
import org.springframework.jdbc.core.RowMapper;
public class HashtableRowMapper implements RowMapper{
public Object mapRow(ResultSet rs, int rowNum) throws SQLException
{
Hashtable hst = new Hashtable();
//hst.put(key, rs.getObject(1));
ResultSetMetaData rmd = rs.getMetaData();
int count = rmd.getColumnCount();
//System.out.println("字段个数为:"+String.valueOf(count));
for(int i=0;i<count;i++)
{
//System.out.println("columnName:"+rmd.getColumnName(i+1));
//System.out.println("columnLabel:"+rmd.getColumnLabel(i+1));
//System.out.println("columnCatalog:"+rmd.getCatalogName(i+1));
System.out.println(rs.getObject(i+1).toString());
hst.put(rmd.getColumnName(i+1), rs.getObject(i+1));
}
return hst;
}
}
//下面是JSP测试页:
<%@ page contentType="text/html;charset=UTF-8"%>
<%@ page import="org.openjweb.core.service.IDBSupportService"%>
<%@ page import="org.openjweb.core.service.ServiceLocator"%>
<%@ page import="org.openjweb.core.entity.*"%>
<%@ page import="org.openjweb.core.util.StringUtil"%>
<%@ page import="org.openjweb.core.util.HashtableRowMapper"%>
<%@ page import="java.util.*"%>
<%
/* ********************************************
* DEMO5: JdbcTemplate
* 因为平台的封装的DAO方法只是最常用的方法,但Spring提供的HibernateTemplate和JdbcTemplate还有很多方法可以使用
* 所以在IDBSupportService提供了调用HibernateTemplate和JdbcTemplate方法的
**********************************************/
IDBSupportService service = (IDBSupportService)ServiceLocator.getService("IDBSupportService3");
List list =
(ArrayList)service.getJdbcTemplate().query("select a.sys_code ,a.sys_nm from comm_sub_system a", new HashtableRowMapper());
//封装在List的Hashtable的key值都是大写的
if(list!=null&&list.size()>0)
{
for(int i=0;i<list.size();i++)
{
//注意没做空值处理,所以String转换可能有异常
Hashtable hst =(Hashtable)list.get(i);
String sysCode = (String)hst.get("SYS_CODE"); //与select中的对应,如果select中取别名,这里也是别名
String sysNm = (String)hst.get("SYS_NM");
out.println(sysCode+"/"+sysNm+"<p>");
}
}
//下面是用jdbctemplat带查询条件的query
List list1 =
(ArrayList)service.getJdbcTemplate().query("select sys_code , sys_nm from comm_sub_system where sys_code like ?",new String[]{"CR%"}, new HashtableRowMapper());
//封装在List的Hashtable的key值都是大写的
if(list1!=null&&list.size()>0)
{
for(int i=0;i<list1.size();i++)
{
//注意没做空值处理,所以String转换可能有异常
Hashtable hst =(Hashtable)list1.get(i);
String sysCode = (String)hst.get("SYS_CODE"); //与select中的对应,如果select中取别名,这里也是别名
String sysNm = (String)hst.get("SYS_NM");
out.println(sysCode+"/"+sysNm+"<p>");
}
}
%>
-- openjweb作者,QQ:29803446
- 使用Spring的JdbcTemplate获得任意表的数据集
- Spring的jdbcTemplate使用
- Spring的jdbcTemplate使用
- Spring的jdbcTemplate使用
- Spring的jdbcTemplate使用
- Spring的jdbcTemplate使用
- Spring的jdbcTemplate使用
- 使用spring的jdbcTemplate
- Spring的JdbcTemplate的使用
- 使用Spring的JdbcTemplate操作数据的方法
- Spring中JdbcTemplate的使用
- spring中JDBCTemplate的使用
- spring 中JdbcTemplate的使用
- spring中JdbcTemplate的使用
- Spring中JdbcTemplate的使用
- Spring的jdbcTemplate使用queryForXXX的使用
- spring的JdbcTemplate的简单使用
- 使用Spring的JdbcTemplate编写的DAO
- sk_buff 功能函数
- c++中临时变量不能作为非const的引用参数
- Solaris下如何编译、安装64位python
- 从 TWAIN 设备中扫描图像
- Python -- The eric Python IDE
- 使用Spring的JdbcTemplate获得任意表的数据集
- Solaris如何确定安装的Python是32位还是64位
- 关于Java中的abstract与interface的讨论
- 深入浅出JSON
- freebsd 安装双 mysql5.1.22 服务
- J2EE应用程序异常处理框架
- S3C2410 && WinCE6.0的中断处理分析
- 工厂模式
- Firefox - 更新 - 3.0.6