@Transactional配置(springmvc+mybatis)

1.spring-mybatis.xml加入配置

<!-- 配置事務管理器 -->
<bean id="transactionManager"
      class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource" />
</bean>

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

2.實例

1)Dao層

UserDaogit

@Repository
public interface UserDao {
    User qryById(Long id);
    List<User> pageUser(@Param("name")String name,Page<User> page);
    int add(User user);
}

UserMapper:設置自增主鍵=》useGeneratedKeys="true" keyProperty="id"github

<insert id="add" useGeneratedKeys="true" keyProperty="id">
    INSERT INTO USER(<include refid="commonColumns"/>)
    VALUES (#{id},#{name},#{birthday})
</insert>

2)Service層

注意項:spring

  • 事務回滾是根據拋出運行時異常(RuntimeException)進行回滾
  • 若是自定義異常DemoException是非運行時異常,也需進行回滾,則須要在@Transactional註解加入rollbackFor指定需回滾的異常。
  • 由於事務配置在Service層,因此在Service層不要進行異常捕獲,不然會形成事務沒法回滾;若代碼中必需要捕獲,請捕獲後再次拋出異常,以此讓事務回滾。

UserService數據庫

@Transactional(rollbackFor = DemoException.class)
public Boolean add(User user) throws DemoException{
    int count = userDao.add(user);

    if(count != 1){
        throw new DemoException("數據庫更新不爲1");
    }

    LOGGER.info("新增user主鍵id=>{}",user.getId());

    if(1 == 1) {
        throw new DemoException("測試事務事務是否回滾");
    }
    return true;
}

3)Controller層

UserControllermybatis

@RequestMapping("add")
@ResponseBody
public Boolean add(User user) throws DemoException{
    return userService.add(user);
}

4)model對象

User:在set日期方法上加入DateTimeFormat格式化app

@DateTimeFormat(pattern = "yyyy-MM-dd")
public void setBirthday(Date birthday) {
    this.birthday = birthday;
}

 

3.工程源碼地址

https://github.com/BAN-WANG/demo測試

相關文章
相關標籤/搜索