spring

一.JDBCTemplate

导入的jar
//创建连接池
 DriverManagerDataSource dmd= new DriverManagerDataSource();
//往连接池里面设置4大参数
     dmd.setDriverClassName( "com.mysql.jdbc.Driver" );
     dmd.setUrl( "jdbc:mysql:///myspring03" );
     dmd.setUsername( "root" );
     dmd.setPassword( "root" );
      //创建jdbcTemplate模板
     JdbcTemplate template = new JdbcTemplate();
      //将连接池设置到模板中
     template.setDataSource(dmd);
=====================

<bean id="ds3" class="com.mchange.v2.c3p0.ComboPooledDataSource">
     <property name="driverClass" value="com.mysql.jdbc.Driver"/>
     <property name="jdbcUrl" value="jdbc:mysql:///myspring03"/>
     <property name="user" value="root"/>
     <property name="password" value="root"></property>
  </bean>
  <bean id=" jdbctemplate" class="org.springframework.jdbc.core.JdbcTemplate">
     <property name="dataSource" ref="ds3"/>
  </bean> -->

引入外部文件:
  <!--外部属性文件的导入 ====================================================== -->
 
    <!--在xml的文件中引入db.properties文件-->
    <!-- <context:property-placeholder location="classpath:db.properties"/> -->
    <!-- 在配置文件中使用配置文件中的信息 -->
   <!--  <bean id="ds4" class="com.mchange.v2.c3p0.ComboPooledDataSource">
       <property name="driverClass" value="${jdbc.driver}"/>
       <property name="jdbcUrl" value="${jdbc.url}"/>
       <property name="user" value="${jdbc.user}"/>
       <property name="password" value="${jdbc.password}"></property>
    </bean>
   <bean id=" jdbctemplate" class="org.springframework.jdbc.core.JdbcTemplate">
     <property name="dataSource" ref="ds4"/>
  </bean> -->
  <!--外部属性文件的导入 ====================================================== end-->
==============



==================



1.1.5Spring的事务管理:

声明事务管理在xml中的配置:(基于AOPxml的配置)
  <!--在xml的文件中引入db.properties文件-->
  < context:property-placeholder location = "classpath:db.properties" />
    <!-- 在配置文件中使用配置文件中的信息 -->
  < bean id = "dataSource" class = "com.mchange.v2.c3p0.ComboPooledDataSource" >
       < property name = "driverClass" value = "${jdbc.driver}" />
       < property name = "jdbcUrl" value = "${jdbc.url}" />
       < property name = "user" value = "${jdbc.user}" />
       < property name = "password" value = "${jdbc.password}" ></ property >
    </ bean >
  < bean id = "accountService" class = "cn.itcast.demo3.AccountServiceImpl" >
     < property name = "accountDao" ref = "accountDao" ></ property >
  </ bean >
 
  < bean id = "accountDao" class = "cn.itcast.demo3.AccountDaoImpl" >
    <!-- 直接注入我们的数据源 -->
    < property name = "dataSource" ref = "dataSource" ></ property >
  </ bean >
 
  <!--注册事务管理器  -->
  < bean id = "transactionManager" class = "org.springframework.jdbc.datasource.DataSourceTransactionManager" >
      <!-- 事务管理器得需要引入我们的连接池即数据源,因为得获得连接,开启事务 -->
      < property name = "dataSource" ref = "dataSource" ></ property >
  </ bean >
  <!--基于 AOP的声明事务管理 -->
  <!--定义一个增强,事务的通知  -->
  < tx:advice id = "txAdvice" transaction-manager = "transactionManager" >
    <!--事务里面的属性  -->
     < tx:attributes >
          < tx:method name = "transf" />
     </ tx:attributes >
  </ tx:advice >
  <!--定义AOP的配置(通知和切点的组合)  -->
  < aop:config >
     < aop:pointcut expression = "execution(* cn.itcast.demo3.AccountService+.*(..))" id = "mypointcut" />
     < aop:advisor advice-ref = "txAdvice" pointcut-ref = "mypointcut" />
  </ aop:config >
 
步骤:
 1>导包 aop tx
 2>在xml中配置
  •      配置数据源
  •      声明目标类,持久层的类。并且在持久层中注入数据源,目的是Dao类继承JdbcDaoSupport。此类帮我们拿到模板,直接注入数据源即可
  •      注册事务管理器。事务管理器中注入数据源!目的是获得连接,开启事务
  •      定义增强。事务管理的  : <tx:Advicer id="" transcation-manager="事务管理器">  事务里面的属性
  •      定义Aop的设置
      
  <!--声明目标类和dao 类。在dao类中注入数据源  -->
  <!--注册事务管理器  -->
  <!--定义增强  -->
  <!--声明一个切面 通知和切点的组合  -->


基于注解的事务管理:

第一步:事务管理器:

<!-- 事务管理器 -->

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

<property name="dataSource" ref="dataSource"/>

</bean>

第二步 : 注解事务 :

<!-- 开启注解的事务管理 -->

<tx:annotation-driven transaction-manager="transactionManager"/>


 第三步: Service 上使用注解

@Transactional

注解中有属性值:

* isolation

* propagation

* readOnly

=====================
  <!--在xml的文件中引入db.properties文件-->
  < context:property-placeholder location = "classpath:db.properties" />
    <!-- 在配置文件中使用配置文件中的信息 -->
  < bean id = "dataSource" class = "com.mchange.v2.c3p0.ComboPooledDataSource" >
       < property name = "driverClass" value = "${jdbc.driver}" />
       < property name = "jdbcUrl" value = "${jdbc.url}" />
       < property name = "user" value = "${jdbc.user}" />
       < property name = "password" value = "${jdbc.password}" ></ property >
    </ bean >
  < bean id = "accountService" class = "cn.itcast.demo4.AccountServiceImpl" >
     < property name = "accountDao" ref = "accountDao" ></ property >
  </ bean >
 
  < bean id = "accountDao" class = "cn.itcast.demo4.AccountDaoImpl" >
    <!-- 直接注入我们的数据源 -->
    < property name = "dataSource" ref = "dataSource" ></ property >
  </ bean >
 
  <!--注册事务管理器  -->
  <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager" >
      <!-- 事务管理器得需要引入我们的连接池即数据源,因为得获得连接,开启事务 -->
      <property name="dataSource" ref="dataSource" ></property>
  </bean >
  <!--基于注解的方式来完成事务的管理  -->
  <tx:annotation-driven transaction-manager="transactionManager" />  

在目标类上加上

@ Transactional
public class AccountServiceImpl implements AccountService {















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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值