Spring结合jdbc以及mybatis事务控制

事务属性包含的五个方面分别是什么
1、事务传播行为
规定了如果有新的事务应该被启动还是被挂起,或者方法是否需要在事务中运行。
TransactionDefinition.PROPAGATION_REQUIRED如果当前存在事务,则加入该事务,如果当前没有事务,则创建一个新的事务。
TransactionDefinition.PROPAGATION_REQUIRES_NEW:创建一个新的事务,如果当前存在事务,则把当前事务挂起。
TransactionDefinition.PROPAGATION_SUPPORTS:如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的方式继续运行。
TransactionDefinition.PROPAGATION_NOT_SUPPORTED:以非事务方式运行,如果当前存在事务,则把当前事务挂起。
TransactionDefinition.PROPAGATION_NEVER:以非事务方式运行,如果当前存在事务,则抛出异常。
TransactionDefinition.PROPAGATION_MANDATORY:如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。
TransactionDefinition.PROPAGATION_NESTED:如果当前存在事务,则创建一个事务作为当前事务的嵌套事务来运行;如果当前没有事务,则该取值等价于TransactionDefinition.PROPAGATION_REQUIRED。
挂起:挂起进程在操作系统中可以定义为暂时被淘汰出内存的进程,机器的资源是有限的,在资源不足的情况下,操作系统对在内存中的程序进行合理性安排,其中有的进程被暂时调离出内存,当条件允许时,会被操作系统再次调回内存,重新进入等待被执行 的状态即就绪状态,系统在超过一定的时间没有任何动作。
2、事务隔离级别
定义了一个事务可能受其他并发事务影响的程度。
隔离级别是指若干个并发的事务之间的隔离程度。TeanscationDefinition接口中定义了五个表示隔离级别的常量。
TranssactionDefinition.ISOLATION_DEFAULT这是默认值,表示使用底层数据库的默认隔离级别。

    1、read_Uncommitted 最低级别隔离 改不改,改成什么都能读。不提交也可以都
    2、read_commited   读提交的数据, 没提交的不能操作
    3、Repeatable 解决不可重复读/脏读  性能下降
    4、Serializable 不能同时操作一个, 一个操作完 下一个

3、事务的只读属性
    定义了一个事务中是否是只读操作,如果设置只读那么数据库内部就可以对操作进行合适的优化措施,只有传播行为是Propagtaion_REQUIRED PROPAGATION_REQUIRES_NEW PROPAGATION_NESTED的时候只读设置才有意义,因为只读优化是在事务开始的时候由数据库事实的,而在这三个传播行为下才有可能启动一个新事物
4、事务超时
    为了使应用程序可以很好的运行,事务不能运行太长的时间,所以这个属性就控制着时间,只有传播行为是PROPAGATION_REQUIRED PROPAGATION_REQUIRES_NEW PROPAGATION_NESTED的时候超时设置才有意义,因为超时时钟会在开始的时候启动,而这三个传播行为下才有可能启动一个新事务,注意事务超时后会自动回滚
5、事务的回滚规则
    定义了哪些异常会导致回滚 而那些不会。默认情况下,事务在遇到运行时异常的时候才会回滚,而遇到检查时异常时不会回滚。
    -Exception表示有Exception抛出 事务回滚
    -表示回滚 +表示提交


脏读:读到了无效的数据。

Spring与jdbc结合
    jdbc编程不变 主要是connection对象的维护,配置并使用数据源。

1)<!-- 基于jdk的规范数据源 -->
 <bean name="dataSource1"
     class="oracle.jdbc.pool.OracleConnectionPoolDataSource">
    <property name="networkProtocol">
        <value>tcp</value>
    </property>
    <property name="databaseName">
        <value>XE</value>
    </property>
    <property name="driverType">
        <value>thin</value>
    </property>
    <property name="portNumber">
        <value>1521</value>
    </property>
    <property name="user">
        <value>briup</value>
    </property>
    <property name="serverName">
        <value>127.0.0.1</value>
    </property>
    <property name="password">
        <value>briup</value>
    </property>
</bean>

注意:别忘了读取配置文件
<!-- 读取这个资源文件 读完之后下面就可以用${key}来去文件中的value值了 -->
<!-- 这种方式是我们第一节学习的那种配置方式方式的简写 -->
<context:property-placeholder location="classpath:oracle.perperties"/>

2)<!-- dbcp数据源 -->
<bean id="dataSource2"
    class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName">
        <value>${driver}</value>
    </property>
    <property name="url">
        <value>${url}</value>
    </property>
    <property name="username">
        <value>${user}</value>
    </property>
    <property name="password">
        <value>${password}</value>
    </property>
    <!-- 最大连接数 -->
    <property name="maxActive">
        <value>80</value>
    </property>
    <!-- 最大空闲连接数 -->
    <property name="maxIdle">
        <value>20</value>
    </property>
    <!-- 最大等待时间:当没有可用连接时,连接池等待连接被归还的最大时间 单位:毫秒 -->
    <!-- 超过时间则抛出异常,如果设置为-1表示无限等待 -->
    <property name="maxWait">
        <value>3000</value>
    </property>
</bean>

3)<!-- spring提供的一种数据源 -->
   <bean id="dataSource3"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName">
        <value>${driver}</value>
    </property>
    <property name="url">
        <value>${url}</value>
    </property>
    <property name="username">
        <value>${user}</value>
    </property>
    <property name="password">
        <value>${password}</value>
    </property>
  </bean>


4)c3p0数据源
<!-- c3p0数据源 -->
<bean id="dataSource4" class="com.mchange.v2.c3p0.ComboPooledDataSource"
    destroy-method="close">
    <property name="driverClass">
        <value>${driver}</value>
    </property>
    <property name="jdbcUrl">
        <value>${url}</value>
    </property>
    <property name="user">
        <value>${user}</value>
    </property>
    <property name="password">
        <value>${password}</value>
    </property>

    <!--连接池中保留的最小连接数。 -->
    <property name="minPoolSize">
        <value>5</value>
    </property>

    <!--连接池中保留的最大连接数。Default: 15 -->
    <property name="maxPoolSize">
        <value>30</value>
    </property>

    <!--初始化时获取的连接数,取值应在minPoolSize与maxPoolSize之间。Default: 3 -->
    <property name="initialPoolSize">
        <value>10</value>
    </property>

    <!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
    <property name="maxIdleTime">
        <value>60</value>
    </property>

    <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 -->
    <property name="acquireIncrement">
        <value>5</value>
    </property>

    <!--每60秒检查所有连接池中的空闲连接。Default: 0 -->
    <property name="idleConnectionTestPeriod">
        <value>60</value>
    </property>

    <!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 -->
    <property name="acquireRetryAttempts">
        <value>30</value>
    </property>
</bean>

-------------------

spring在jdbc中还提供了模板类 jdbcTemplate
<bean name="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <constructor-arg index="0" ref="dataSource"></constructorarg>
</bean>-

<bean name="dao" class="com.briup.db.jdbc.JdbcTemplateDao">
    <property name="jdbcTemplate" ref="jdbcTemplate"></property>
</bean>
重点1、jdbcTemplate模板类如何使用:在htmlsingle中搜索即可,其中包含大量使用实例,
重点2、spring结合jdbc时候,不论是否使用这个模板,jdbc事务都是默认提交的。

2、Spring与mybatis结合
注意使用jar包 mybatis-spring-1.2.2.jar

使用spring整合mybatis时,可以使用mybatis-config.xml文件,也可以不使用。
<!--配置sqlSessionFactory不使用mybatis-config.xml>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="typeAliasesPackage" value="com.briup.db"></property>
    <property name="configurationProperties">
        <props>
            <prop key="cacheEnabled">true</prop> 
        </props>
    </property>
    <!-- 自动扫描mapping.xml文件 -->
    <property name="mapperLocations" value="classpath:com/briup/db/mybatis/AccountMapper.xml" />
</bean> 

或者:

<!-- 配置sqlSessionFactory 使用mybatis-config.xml-->
<!-- 直接读取mybatis-config.xml文件,里面和之前配置的一样 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="configLocation"  value="classpath:mybatis-config.xml"/>
</bean>

最后还需要扫描mybatis中映射接口,以便spring为其生产对应的实现类
<!-- 自动扫描映射接口所在的包 -->
<!-- 将来可以通过接口的名字首字母小写作为beanName,从spring容器中拿出自动生成的该接口的实现类 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="basePackage" value="com.briup.db" />
</bean>

3、spring事务管理机制
    1、编程式事务管理(不常用)
    所谓编程式事务指的是通过编码方式实现事务
    2、声明式事务管理(常用)
    在spring配置文件中声明式处理事务来代替代码式的处理事务。
    在spring中声明式事务主要是通过 事务属性 来定义的,事务属性描述了事务策略如何应用到方法上面。
    事务属性主要包含了以下五个方面/
    传播行为 隔离级别 回滚规则 事务超时  是否只读

声明式事务管理的配置方式通常有以下几种:
    注意:配置事务的方式都需要用到事务管理器(切面)和事务拦截器(advice),其实就是aop编程,把事务代码织入到需要使用的方法上。

    spring中实现的aop配置方式很多,在这里配置事物的时候推荐使用。
    1、tx前缀的事务标签和aop前缀的标签结合,将切面 事务管理器 织入到切入点上
    2、注解进行事物配置

    spring结合jdbc,事务配置在service层指定方法上,使用tx标签结合aop标签
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值