`
cjc
  • 浏览: 683670 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

使用Spring的JdbcTemplate获得任意表的数据集

阅读更多

因为使用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 的使用.doc

    JdbcTemplate的`execute()`方法可以用来执行任意的SQL语句,包括DDL(数据定义语言)如创建表。在示例中,`execute()`方法被用来创建名为USER的表,包含user_id整型字段和name变长字符串字段。 2. **插入和更新...

    jdbcTemplate.jar

    在与MySQL等数据库配合使用时,`jdbcTemplate`能很好地处理各种数据类型和复杂查询,如JOIN、子查询等。同时,它提供了异常处理机制,当数据库操作失败时,会抛出相应的异常,帮助开发者快速定位问题。 总结起来,`...

    JdbcTemplate.jar

    JdbcTemplate是Spring提供的一个模板类,它是基于JDBC但又对JDBC进行了高度封装,旨在减少数据库访问时的繁琐代码,如打开和关闭连接、处理结果集等。它通过预编译的SQL语句、批处理以及异常转换等功能,实现了...

    jdbcTemplate封装工程需要的jar包

    1. **Spring JDBC模块**:`JdbcTemplate`位于Spring的JDBC模块中,它简化了数据库访问,通过消除大量的样板代码,如处理结果集、事务管理和异常转换。使用`JdbcTemplate`,开发者可以专注于业务逻辑,而不用过于关心...

    JDBCTemplate.zip

    在实际使用中,首先需要配置数据源(如Druid连接池),然后在Spring配置文件中声明JDBCTemplate的bean,注入数据源。接着,在业务逻辑代码中,通过@Autowired注解注入JDBCTemplate实例,调用其提供的方法进行数据库...

    jdbcTemplate的使用方法.pdf

    使用JdbcTemplate的`execute()`方法可以执行任意的SQL语句,包括创建表、删除表等DDL操作。例如: ```java jdbcTemplate.execute("CREATE TABLE USER (user_id integer, name varchar(100))"); ``` 2. **插入...

    spring_JdbcTemplete使用详解

    ### Spring JDBC 模板类(JdbcTemplate)使用详解 #### 一、Spring JDBC 概述 Spring 提供了一个强大的模板类 `JdbcTemplate` 来简化 JDBC 操作。通过使用 `JdbcTemplate`,开发者能够减少大量的样板代码,提高...

    Spring JDBC实现代码

    JdbcTemplate提供了各种方法,如update()用于执行SQL更新,query()用于查询数据,以及execute()用于执行任意的SQL语句。 在Spring 2.5中,我们可以创建一个JdbcTemplate实例并注入DataSource,如下所示: ```java ...

    spring3.x 实战资源教程

    - **类**:`JdbcTemplate`,提供了一系列方便的方法处理SQL语句执行和结果集解析。 #### 6.3 关系数据库操作对象化 - **概念**:使用对象模型来操作数据库,减少SQL语句编写。 #### 6.4 Spring提供的其他帮助 - **...

    Dim ds As New DataSet_java_

    标题中的“Dim ds As New DataSet_java_”是一个VB.NET代码片段,它声明并初始化了一个名为`ds`的数据集(DataSet)对象。数据集是.NET框架中的一个类,它用于存储和处理关系型数据,通常是从数据库中检索的。在Java...

    java分页技术参考

    Java 分页技术是Java Web开发中常用的一种技术,主要用于处理大量数据时,避免一次性加载所有数据导致内存压力和用户体验下降。...分页设计还应考虑到错误处理和特殊情况的处理,例如处理空数据集或无效的页码请求。

    struts2+MySQL分页(精).pdf

    同时,为了提高代码的可维护性和重用性,可以考虑使用更高级的DAO设计模式,比如工厂模式或Spring的JdbcTemplate。 在整合jQuery框架时,可以利用其强大的AJAX功能,使分页操作无刷新,提供更流畅的用户体验。例如...

Global site tag (gtag.js) - Google Analytics