Spring JdbcTemplate例子

[b]Spring的JDBCTemplate[/b]

当hql等查询方式不能满足性能或灵活性的要求,必须使用SQL时,大家有三种选择:

第一、使用Hibernate 的sql 查询函数,将查询结果对象转为Entity对象。

第二、使用Hibernate Session的getConnection 获得JDBC Connection,然后进行纯JDBC API操作;

第三、选择把Spring的JDBCTemplate作为一种很不错的JDBC Utils来使用。

[b]JdbcTemplate类[/b]
JdbcTemplate是core包的核心类。它替我们完成了资源的创建以及释放工作,从而简化了我们对JDBC的使用。它还可以帮助我们避免一些常见的错误,比如忘记关闭数据库连接。JdbcTemplate将完成JDBC核心处理流程,比如SQL语句的创建、执行,而把SQL语句的生成以及查询结果的提取工作留给我们的应用代码。它可以完成SQL查询、更新以及调用存储过程,可以对ResultSet进行遍历并加以提取。它还可以捕获JDBC异常并将其转换成org.springframework.dao包中定义的,通用的,信息更丰富的异常。

下面看看我做的例子
包结构,还有需要的jar包,数据库用的是oracle,表用的事scott下面的Dept表,这里是主要代码,如果想看全部请下载附件例子。

[img]http://dl.iteye.com/upload/attachment/0073/4523/6f0b0092-f6f6-3f91-9b6a-cbf6048f4887.jpg[/img]


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>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值