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

  • 相关阅读:
    使用composer命令加载vendor中的第三方类库
    微信小程序
    php无限分类方法类
    php的多功能文件操作类
    计算地图上两点间的距离PHP类
    php的微信公众平台开发接口类
    身份证验证PHP类
    PHP实现微信对账单处理
    PHP实现微信退款功能
    sqlserver 多库查询 sp_addlinkedserver使用方法(添加链接服务器)
  • 原文地址:https://www.cnblogs.com/huapox/p/3172500.html
Copyright © 2011-2022 走看看