当hql等查询方式不能满足性能或灵活性的要求,必须使用SQL时,大家有三种选择:
第一、使用Hibernate 的sql 查询函数,将查询结果对象转为Entity对象。
第二、使用Hibernate Session的getConnection 获得JDBC Connection,然后进行纯JDBC API操作;
第三、选择把Spring的JDBCTemplate作为一种很不错的JDBC Utils来使用。
JdbcTemplate类
JdbcTemplate是core包的核心类。它替我们完成了资源的创建以及释放工作,从而简化了我们对JDBC的使用。它还可以帮助我们避免一些常见的错误,比如忘记关闭数据库连接。JdbcTemplate将完成JDBC核心处理流程,比如SQL语句的创建、执行,而把SQL语句的生成以及查询结果的提取工作留给我们的应用代码。它可以完成SQL查询、更新以及调用存储过程,可以对ResultSet进行遍历并加以提取。它还可以捕获JDBC异常并将其转换成org.springframework.dao包中定义的,通用的,信息更丰富的异常。
下面看看我做的例子
包结构,还有需要的jar包,数据库用的是oracle,表用的事scott下面的Dept表,这里是主要代码,如果想看全部请下载附件例子。
package com.jiaozg.dao; import java.math.BigDecimal; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import java.util.Map; import org.springframework.jdbc.core.JdbcTemplate; import com.jiaozg.model.Dept; import com.jiaozg.util.SpringUtil; 主要类: public class DeptDao { private JdbcTemplate jdbcT; public void setJdbcT(JdbcTemplate jdbcT) { this.jdbcT = jdbcT; } public List findALL() { String sql = "select * from dept"; return jdbcT.queryForList(sql); } public List<Dept> findALLDepts() { List<Dept> depts = new ArrayList<Dept>();; String sql = "select * from Dept"; List list = jdbcT.queryForList(sql); Iterator iterator = list.iterator(); Dept dept = null; while (iterator.hasNext()) { Map map4dept = (Map) iterator.next(); dept = new Dept(); dept.setDeptNo(((BigDecimal) map4dept.get("DEPTNO")).intValue()); dept.setDName((String)map4dept.get("DNAME")); dept.setLoc((String)map4dept.get("LOC")); depts.add(dept); } return depts; } public int delete(int bid){ String sql = "delete from DeptInfo where bid =?"; return jdbcT.update(sql, new Object[]{bid}); } public static void main(String[] args) { DeptDao dao = (DeptDao) SpringUtil.getBean("deptDao"); List<Dept> depts = dao.findALLDepts();; for(Dept dept:depts){ System.out.println(dept.getDeptNo()+","+dept.getDName()+","+dept.getLoc()); } System.out.println("---------------------------------"); List list = dao.findALL(); for(Iterator it = list.iterator(); it.hasNext(); ) { System.out.println(it.next()); } } }
public class SpringUtil { private static ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml"); public static Object getBean(String beanName){ return ctx.getBean(beanName); } }
主要配置文件
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd"> <bean id="springDSN" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"> </property> <property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:orcl"> </property> <property name="username" value="scott"></property> <property name="password" value="Qwer1234"></property> </bean> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" abstract="false" lazy-init="false" autowire="default" dependency-check="default"> <property name="dataSource"> <ref bean="springDSN" /> </property> </bean> <bean id="deptDao" class="com.jiaozg.dao.DeptDao"> <property name="jdbcT"> <ref bean="jdbcTemplate" /> </property> </bean> </beans>