Spring-继承JdbcDaoSupport类后简化配置文件内容

正常情况下,我们在实现类中想要晕用模板类需要在配置文件中注入连接池,再将连接池注入给模板类,然后在实现类中得到。

 1 <!-- 配置C3P0连接池 -->
 2     <bean id = "dataSource" class = "com.mchange.v2.c3p0.ComboPooledDataSource">    
 3         <property name="driverClass" value = "com.mysql.jdbc.Driver"/>
 4         <property name="jdbcUrl" value = "jdbc:mysql:///spring_day03"/>
 5         <property name="user" value = "root"/>
 6         <property name="password" value = "123456"/>
 7     </bean>
 8     
 9     <!-- 配置JDBC模板类 -->
10     <bean id = "jdbcTemplate" class = "org.springframework.jdbc.core.JdbcTemplate">
11         <property name="dataSource" ref = "dataSource"></property>
12     </bean>
13     
14    <!--配置持久层-->
15     <bean id = "accountDao" class = "com.itheima.demo1.AccountDaoImpl" >
16         <property name="jdbcTemplate" ref = "jdbcTemplate"></property>        
17     </bean>
1 public void dao{
2 
3         private JdbcTemplate jdbcTemplate;
4         public void setJdbcTemplate(JdbcTemplate jdbcTemplate){
5                       this.jdbcTemplate = jdbcTemplate;
6         }
7     
8 }       

但是,有一个JdbcDaoSupport类,继承了它之后就可以不用配置模板类,具体看源码

public final void setDataSource(DataSource dataSource){
           if(this.jdbcTemplate == null || dataSource != this.jdbcTemplate.getDataSource())
           this.jdbcTemplate = createJdbcTemplate(dataSource);
          initTemplateConfig();
}

源码中说的很清楚了,如果你没有提供模板类,它会根据连接池(dataSource)来新建一个模板类,这样,我们在配置文件中只需要配置连接池就好了,不用再配置模板类,模板类的工作交给它来做。

<!-- 配置C3P0连接池 -->
    <bean id = "dataSource" class = "com.mchange.v2.c3p0.ComboPooledDataSource">    
        <property name="driverClass" value = "com.mysql.jdbc.Driver"/>
        <property name="jdbcUrl" value = "jdbc:mysql:///spring_day03"/>
        <property name="user" value = "root"/>
        <property name="password" value = "123456"/>
    </bean>

    <bean id = "accountDao" class = "com.itheima.demo1.AccountDaoImpl" >
        <property name = "dataSource" ref = "dataSource"/>        
    </bean>

那么我们怎么用模板类呢,不用担心,父类JdbcDaoSuppor中有相关的获取方法,可以直接拿来用

1 //扣钱
2     @Override
3     public void outMoney(String out, double money) {
4         this.getJdbcTemplate().update(sql, args);
5         
6     }

参考 黑马JAVAEE教学视频

转载于:https://www.cnblogs.com/deepSleeping/p/7099150.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值