zoukankan      html  css  js  c++  java
  • JdbcDaoSupport应用

    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

  • 相关阅读:
    android引入百度地图之最简单的例子-HelloBaiDuMap
    WebView之js调用Android类的方法传递数据
    eclipse项目中丢失的R包找回方法
    画竖线的4种方法
    CSS清除浮动的三种方法
    css简写
    使用CSS设置行间距,字间距
    PHP面试题及答案解析(5)—数据结构与算法
    PHP面试题及答案解析(6)—PHP网络编程
    PHP面试题及答案解析(3)—MySQL数据库
  • 原文地址:https://www.cnblogs.com/huapox/p/3172500.html
Copyright © 2011-2022 走看看