zoukankan      html  css  js  c++  java
  • SpringBoot事务管理

    1、在UserMapper接口中添加更新和删除方法

    package com.cppdy.mapper;
    
    import org.apache.ibatis.annotations.Delete;
    import org.apache.ibatis.annotations.Insert;
    import org.apache.ibatis.annotations.Mapper;
    import org.apache.ibatis.annotations.Param;
    import org.apache.ibatis.annotations.Select;
    import org.apache.ibatis.annotations.Update;
    
    import com.cppdy.entity.User;
    
    @Mapper
    public interface UserMapper {
    
        @Select("select * from user where id=#{id}")
        User getUserById(@Param("id") int id);
    
        @Insert("insert into user values(NULL,#{name})")
        User insertUser(@Param("name") String name);
        
        @Update("update user set username=#{name} where id=#{id}")
        User update(@Param("id") int id,@Param("name") String name);
        
        @Delete("delete from user where id=#{id}")
        User delete(@Param("id") int id);
    }

    2、创建UserService接口

    package com.cppdy.service;
    
    public interface UserService {
        
        //执行事务
        public void tranfor();
    
    }

    3、创建UserServiceImpl实现类(@Transactional开启事务管理)

    package com.cppdy.service.impl;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    import org.springframework.transaction.annotation.Transactional;
    
    import com.cppdy.mapper.UserMapper;
    import com.cppdy.service.UserService;
    
    @Service
    public class UserServiceImpl implements UserService {
    
        @Autowired
        private UserMapper userMapper;
    
        // 开启事务管理
        @Transactional
        public void tranfor() {
            // 更新一条数据
            userMapper.update(2, "cppdy123");
            // 抛出一个异常
            int a = 2 / 0;
            // 删除一条数据
            userMapper.delete(2);
        }
    
    }

    4、在HelloWordController类中创建测试方法

    @RequestMapping("tranfor")
        public void tranfor() {
    
            userService.tranfor();
        }
  • 相关阅读:
    【转载】MongoDB 数据库的备份与恢复
    【转载】Vim命令合集
    【转载】Mac 让 iTerm2 记住用户名密码
    CSS 实现单行、多行文本溢出显示省略号
    【转载】如何在Vue2中实现组件props双向绑定
    JavaScript 获取当日在今年第几周
    CentOS 7 安装配置FTP服务器(vsftpd)
    CentOS 7 防火墙(firewall)常用命令
    Vs Code 之 实现右键打开文件夹
    git 报错
  • 原文地址:https://www.cnblogs.com/jiefu/p/10048016.html
Copyright © 2011-2022 走看看