1技术上
数据事物管理 SpringMvc
今天面试官 问我的时候 结合实际的项目 我这边的事物管理 是基于XML
spring事务管理
事务,简单的说,就是对于一个操作来说,要么都成功,要么都失败,这样可以保证数据的一致性,在spring mvc中也可以配置相应的事务管理器,有两种实现方法:XML和注解。
XML配置方式实现事务
在spring配置文件中,初始化一个事务管理器,同时将数据源注入:
- <span style="font-size:18px;"><bean id="transactionManager"
- class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="druidDataSource" />
- </bean></span>
- <span style="font-size:18px;"><tx:advice id="txAdvice" transaction-manager="transactionManager">
- <tx:attributes>
- <tx:method name="find*" read-only="true" />
- <tx:method name="update*" propagation="REQUIRED" />
- <tx:method name="delete*" propagation="REQUIRED" />
- <tx:method name="save*" propagation="REQUIRED" />
- </tx:attributes>
- </tx:advice></span>
name属性定义在哪些方法上调用;
propagation定义了该事务的传播属性,默认值为REQUIRED,作用是“支持当前事务,如果当前没有事务,就新建一个事务,即只有一个事务,出现异常时该事务内的所有操作都会回滚”,其他6个值可在api上查到,一般选择默认值;
read-only作用是“只接受只读操作”,默认值为false,若配置为true,当配置的方法中出现对数据库的增删改时,会报异常如:Caused by: java.sql.SQLException: Connection is read-only. Queries leading to data modification are not allowed,适当的配置该属性可提高性能。
最后配置该事务的切面,事务配置完成:
- <span style="font-size:18px;"><aop:config>
- <!-- 定义一个切入点 -->
- <aop:pointcut id="interceptorPointCuts"
- expression="execution(* com.jk.service.impl.*Impl.*(..)) or execution(* com.jk.dao.*.*(..))" />
- <!-- 对切入点和事务的通知,进行适配 -->
- <aop:advisor advice-ref="txAdvice" pointcut-ref="interceptorPointCuts" />
- </aop:config></span>
1 注解方式实现事务
同样的,在spring配置文件中,初始化一个事务管理器,同时将数据源注入:
- <span style="font-size:18px;"><span style="font-size:18px;"><bean id="transactionManager"
- class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="druidDataSource" />
- </bean></span></span>
<tx:annotation-driven transaction-manager="transactionManager"/>
这样就可以在代码中使用事务的注解了,在需要事务的方法上加上,其中各属性与xml配置中的相同:
@Transactional(propagation=Propagation.REQUIRED,rollbackForClassName="Exception")
3 阐述项目中 的问题
1数据量查询慢的问题
2 数据加载
3 redis
4 阐述自己的一块熟悉的业务 叙述怎么完成的