您的位置:首页 > 其它

JdbcDaoSupport应用

2013-02-28 13:24 330 查看
JdbcDaoSupport是JDBC数据访问对象的超类。它与特定的数据源相关联。Spring Inversion of Control (IOC)容器或BeanFactory负责获得相应数据源的配置详细信息,并将其与JdbcDaoSupport相关联。这个类最重要的功能就是使子类可以使用JdbcTemplate对象。


图2:Spring JDBC框架的主要组件

#p#

JdbcTemplate是Spring JDBC框架中最重要的类。引用文献中的话:“它简化了JDBC的使用,有助于避免常见的错误。它执行核心JDBC工作流,保留应用代码以提供SQL和提取结果。”这个类通过执行下面的样板任务来帮助分离JDBC DAO代码的静态部分:

◆从数据源检索连接。

◆准备合适的声明对象。

◆执行SQL CRUD操作。

◆遍历结果集,然后将结果填入标准的collection对象。

◆处理SQLException异常并将其转换成更加特定于错误的异常层次结构。

应用实例:

1.applicationContext.xml配置文件:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">

<beans>

<bean id="myDataSource"

class="org.apache.commons.dbcp.BasicDataSource"

destroy-method="close">

<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />

<property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:lrmora9" />

<property name="username" value="dmis2006_sj" />

<property name="password" value="omssj" />

<property name="maxActive" value="5" />

<property name="maxIdle" value="3" />

<property name="minIdle" value="2" />

<property name="maxWait" value="2" />

<property name="initialSize" value="1" />

<property name="removeAbandoned" value="true" />

<property name="removeAbandonedTimeout" value="180" />

<property name="logAbandoned" value="true" />

</bean>

<bean id="jdbcDao" class="com.lrm.study.jdbc.SpringJdbcDaoSupportApp">

<property name="dataSource">

<ref bean="myDataSource" />

</property>

</bean>

</beans>

2.测试类:

package com.lrm.study.springJDBCDao;

import java.util.List;

import java.util.Map;

import org.springframework.context.ApplicationContext;

import org.springframework.context.support.ClassPathXmlApplicationContext;

import org.springframework.jdbc.core.support.JdbcDaoSupport;

public class SpringJdbcDaoSupportApp extends JdbcDaoSupport{

/**

on May 10, 2010 by lrm

*/

public static void main(String[] args) {

//applicationContext.xml这个文件放到src下,如果报找不到这样的文件,直接拷贝到web-root下的classes下

ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");

SpringJdbcDaoSupportApp jdbcDao = (SpringJdbcDaoSupportApp) ctx.getBean("jdbcDao");

String sql = "select t.ftypename from dmis_eqptype t where t.fcategory = '保护'";

List reList = jdbcDao.queryListBySql(sql);

if(reList.size()>0){

for (int i = 0; i < reList.size(); i++) {

String typename = ((Map)reList.get(i))==null?"":((Map)reList.get(i)).get("ftypename").toString();

System.out.println(typename);

}

}

}

public List queryListBySql(String sql){

return this.getJdbcTemplate().queryForList(sql);

}

}

注意:这里需求相关的jar包支持,否则会报错.commons-dbcp-1.2.1.jar ;commons-pool-1.2.jar ;commons-collections-3.1.jar; spring-1.2.6.jar; spring-aop.jar;ojdbc14.jar
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: