Spring 3事物

//配置完xml文件后,在测试类中使用注解来直接获取xml,这样一来就可以快速获取xml对象(使用自动装配)  只有基于注解配置时才可以使用这个方法
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:xml/beans.xml")

//通过jdbcTemplate来写sql语句
//关于jdbcTemplate的原始使用方法(底层)
//创建jdbc模板对象
JdbcTemplate jdbcTemplate = new JdbcTemplate();
//创建数据源对象
DriverManagerDatasource dataSource = new DriverManagerDatasource();
//设置数据源信息
dataSource.setUrl("jdbc:mysql://localhost:3306/数据库名");
dataSource.setUsername("root");
dataSource.setPassword("password");
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
jdbcTemplate.setDataSource(dataSource);
//然后就可以使用jdbcTemplate来使用数据库,也可以使用构造方法传递数据源信息

//实际使用中,在Dao层写jdbcTemplate,用set方法注入
//在xml中配置
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></property>
    <property name="url" value="jdbc:mysql://localhost:3306/bookstore?characterEncoding=utf8&amp;useSSL=false&amp;serverTimezone=UTC&amp;rewriteBatchedStatements=true"></property>
    <property name="username" value="root"></property>
    <property name="password" value="password"></property>
</bean>

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean>

//通过jdbcTemplate查询所有User信息
//先定义一个RowMapper类
class UserRowMapper implements Rowmapper<User>{
//重写方法(ResultSet resultSet,int i)throws...{
User user = new User();
//使用set方法,将查询到的数据存储到创建的对象中
user.setId(resultSet.getInt("id"));
user.setxxxxxxxxgetString("userName")
}}
//然后再Dao层中的查询方法中
List<User> userList = jdbcTemplate.query("select * from 表名",new UserRowMapper());
return userList;
//返回集合对象后,在测试类中遍历集合对象
for(User user :userByAll){
System.out.println(user);}

//如果是查询一个数据,只需要对sql语句修改,然后返回userList.get(0),就可以只返回一个数据而不是集合

//使用注解配置事物时,操作相同,用@Autowired注解配置在jdbcTemplate上(Dao)层中

### Spring事务管理配置与使用示例 Spring 事务管理通过声明式事务控制来简化开发,减少手动管理事务的复杂性。以下是一个完整的事务管理配置和使用的示例。 #### 配置事务管理器 在基于 XML 的配置中,可以使用 `JpaTransactionManager` 或 `DataSourceTransactionManager` 来管理事务。以下是使用 `DataSourceTransactionManager` 的配置示例[^5]: ```xml <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> <!-- 开启事务注解支持 --> <tx:annotation-driven transaction-manager="transactionManager"/> ``` 如果使用 JPA,则可以配置 `JpaTransactionManager`: ```xml <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> <property name="entityManagerFactory" ref="entityManagerFactory"/> </bean> <!-- 开启事务注解支持 --> <tx:annotation-driven transaction-manager="transactionManager"/> ``` #### 使用 @Transactional 注解 在服务层方法上使用 `@Transactional` 注解来定义事务行为。以下是一个简单的事务管理示例[^4]: ```java @Service public class UserService { @Autowired private UserDao userDao; @Transactional public void createUser(User user) { userDao.createUser(user); if ("error".equals(user.getUsername())) { throw new RuntimeException("Simulated exception for rollback"); } } @Transactional public void updateUser(User user) { userDao.updateUser(user); if ("error".equals(user.getUsername())) { throw new RuntimeException("Simulated exception for rollback"); } } } ``` #### 事务传播行为 事务传播行为决定了当前事务与新事务之间的关系。例如,`Propagation.REQUIRED` 是默认值,表示如果有现有事务则加入该事务,否则创建一个新事务[^1]。 ```java @Transactional(propagation = Propagation.REQUIRED) public void requiredTransaction() { // 业务逻辑 } @Transactional(propagation = Propagation.REQUIRES_NEW) public void requiresNewTransaction() { // 新事务独立运行 } ``` #### 注意事项 1. **内部调用问题**:在同一类中调用被 `@Transactional` 注解的方法时,事务可能不会生效。这是因为 Spring AOP 动态代理无法拦截类内部的方法调用[^3]。 2. **异常处理**:只有未捕获的受检异常或运行时异常才会触发回滚,默认情况下,已捕获的异常不会导致事务回滚[^2]。 3. **只读事务**:对于只读操作,可以通过设置 `readOnly=true` 提高性能,避免不必要的锁[^1]。 ```java @Transactional(readOnly = true) public List<User> findAllUsers() { return userDao.findAll(); } ``` ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值