时间:2021-05-19
我们在SpringBoot和MyBatis整合的时候,需要在SpringBoot中通过注解方式配置事务回滚
1 Pojo类
package com.zxf.domain;import java.util.Date;public class User { private Integer id; private String name; private String pwd; private String head_img; private String phone; private Date create_time; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPwd() { return pwd; } public void setPwd(String pwd) { this.pwd = pwd; } public String getHead_img() { return head_img; } public void setHead_img(String head_img) { this.head_img = head_img; } public String getPhone() { return phone; } public void setPhone(String phone) { this.phone = phone; } public Date getCreate_time() { return create_time; } public void setCreate_time(Date create_time) { this.create_time = create_time; }}2 Mapper接口
我们这里使用注解的方式编写SQL语句
package com.zxf.mapper;import com.zxf.domain.User;import org.apache.ibatis.annotations.Insert;import org.springframework.stereotype.Repository;@Repositorypublic interface UserMapper { @Insert("insert into user (name,pwd,head_img,phone,create_time) values(#{name},#{pwd},#{head_img},#{phone},#{create_time})") public int save(User user);}3 Service接口和实现类
package com.zxf.service;import com.zxf.domain.User;public interface UserService { public int save(User user);}package com.zxf.service.impl;import com.zxf.domain.User;import com.zxf.mapper.UserMapper;import com.zxf.service.UserService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import org.springframework.transaction.annotation.Transactional;@Service@Transactional //实现事务的时候要在业务类中加入该注解public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public int save(User user) { int f= userMapper.save(user); // int x=5/0; return f; }}4 Controller层
package com.zxf.controller;import com.zxf.domain.User;import com.zxf.service.UserService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import java.util.Date;@RestController@RequestMapping("api/v1/user")public class UserController { @Autowired private UserService userService; @RequestMapping("save") public Object save(){ User user=new User(); user.setName("zhang3"); user.setPwd("abc123"); user.setCreate_time(new Date()); user.setPhone("1789238734"); user.setHead_img("aabbddd.jpg"); userService.save(user); return user; }}5 application.properits 配置文件
spring.datasource.driver-class-name =com.mysql.jdbc.Driverspring.datasource.url=jdbc:mysql://localhost:3306/onlinespring.datasource.username=rootspring.datasource.password=******mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl6 pom文件
<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://.zxf.mapper")//扫描mapper接口@EnableTransactionManagement//事务处理的时候启动类必须要加的注解public class XfSpring2Application { public static void main(String[] args) { SpringApplication.run(XfSpring2Application.class, args); }}7 也是最重要,也是很多人忽视的地方,就是MySQL要支持事务处理才可以
这里一定要记住;否则你的SpringBoot的事务没有任何效果
到此这篇关于使用SpringBoot注解方式处理事务回滚实现的文章就介绍到这了,更多相关SpringBoot注解处理事务回滚内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、MyBatis单独使用时,使用SqlSession来处理事务:publicclassMyBatisTxTest{privatestaticSqlSessio
前言:在service层的方法上使用@Transactional即可实现处理数据库发生错误时触发事务回滚机制。注意:Spring基于注解的声明式事物@Trans
事务回滚回滚逻辑如下:判断是否存在事务,只有存在事务才执行回滚根据异常类型判断是否回滚。如果异常类型不符合,仍然会提交事务回滚处理详细解析判断是否存在事务,只有
MySQLProxy最强大的一项功能是实现“读写分离(Read/WriteSplitting)”。基本的原理是让主数据库处理事务性查询,而从数据库处理SELEC
MYSQL的事务处理主要有两种方法。1、用begin,rollback,commit来实现begin开始一个事务rollback事务回滚commit事务确认2、