文档章节

Spring 事务隔离级别 Isolation.SERIALIZABLE) 实验总结

LYQ1990
 LYQ1990
发布于 2016/05/05 10:50
字数 410
阅读 773
收藏 1

一、模拟问题:同一个用户连续点击保存按钮,造成保存重复问题。(第二次请求,查询时,第一次还没有保存到数据库)

 

@Service

@Transactional

public class TestUserImpl implements TestUserService {

 

    public void saveUserAll(int  userId) {

        //1、判断是否已经存在

        boolean result = this.getUser(userId);

        try {

            Thread.sleep(15000);

        } catch (Exception e) {

            e.printStackTrace();

        }

        //2、不存在,保存

        if (result) {this.saveUser(userId);}else{System.out.println("用户已经存在userId="+userId);}

    }

    @Transactional(isolation = Isolation.SERIALIZABLE)

    public void saveUser(int userId) {

        System.out.println("开始保存----userId="+userId);

        User user= new User();

        user.setUserId(userId);

        userDao.save(user);

        System.out.println("完成保存----userId="+userId);

    }

 

    public boolean getUser(int userId) {

        System.out.println("查询----userId="+userId);

        String sql = "SELECT id from  user where userId="+userId+"";

        List list = userDao.findBysql(sql);

        if (list.size() > 0) {

            return false;

        } else {

            return true;

        }

    }

}

------------------------输出结果------------------------------

查询----userId=1

查询----userId=1

开始保存----userId=1

完成保存----userId=1

开始保存----userId=1

完成保存----userId=1

---------------------解决办法:在saveUserAll方法上加锁synchronized----------------------

    public  synchronized void saveUserAll(int  userId)

-----------------------------------------------------------------------------------------------------------------------

二、在saveUserAll上加SERIALIZABLE,同意用户连续点击或不同用户并发请求时,造成死锁

@Service

@Transactional

public class TestUserImpl implements TestUserService {

    @Transactional(isolation = Isolation.SERIALIZABLE)

    public void saveUserAll(int  userId) {

        //1、判断是否已经存在

        boolean result = this.getUser(userId);

        try {

            Thread.sleep(15000);

        } catch (Exception e) {

            e.printStackTrace();

        }

        //2、不存在,保存

        if (result) {this.saveUser(userId);}else{System.out.println("用户已经存在userId="+userId);}

    }

   

    public void saveUser(int userId) {

        System.out.println("开始保存----userId="+userId);

        User user= new User();

        user.setUserId(userId);

        userDao.save(user);

        System.out.println("完成保存----userId="+userId);

    }

 

    public boolean getUser(int userId) {

        System.out.println("查询----userId="+userId);

        String sql = "SELECT id from  user where userId="+userId+"";

        List list = userDao.findBysql(sql);

        if (list.size() > 0) {

            return false;

        } else {

            return true;

        }

    }

}

------------------------输出结果----------------------------------------------------------------------

查询----userId=1

查询----userId=2

开始保存----userId=1

开始保存----userId=2

成功保存----userId=1

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLTransactionRollbackException: Deadlock found when trying to get lock; try restarting transaction

----------------------------------------------------------------------------------------------------------------------

© 著作权归作者所有

LYQ1990
粉丝 9
博文 238
码字总数 206220
作品 0
东城
私信 提问
事务注解 @Transactional

1、当标于类前时, 标示类中所有方法都进行事务处理 某些方法不需要事务时 事务传播行为 @Transactional(propagation=Propagation.REQUIRED) : 如果有事务, 那么加入事务, 没有的话新建一个(...

Java搬砖工程师
2018/07/11
62
0
Spring 使用注解方式进行事务管理

大家在使用spring的注解式事务管理时,对事务的传播行为和隔离级别可能有点不知所措,下边就详细的介绍下以备方便查阅。 事物注解方式: @Transactional 当标于类前时, 标示类中所有方法都进行...

underA
2013/09/15
526
0
Spring 使用注解方式进行事务管理

大家在使用spring的注解式事务管理时,对事务的传播行为和隔离级别可能有点不知所措,下边就详细的介绍下以备方便查阅。 事物注解方式: @Transactional 当标于类前时, 表示类中所有方法都进行...

kunkunkun
2014/03/14
49
0
Spring 注解方式实现 事务管理

使用步骤: 步骤一、在spring配置文件中引入tx:命名空间 <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="h......

北方攻城师
2014/08/10
211
0
Spring 使用注解方式进行事务管理

使用步骤: 步骤一、在spring配置文件中引入tx:命名空间 <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="h......

binhu
2014/07/21
187
0

没有更多内容

加载失败,请刷新页面

加载更多

OpenStack 简介和几种安装方式总结

OpenStack :是一个由NASA和Rackspace合作研发并发起的,以Apache许可证授权的自由软件和开放源代码项目。项目目标是提供实施简单、可大规模扩展、丰富、标准统一的云计算管理平台。OpenSta...

小海bug
昨天
5
0
DDD(五)

1、引言 之前学习了解了DDD中实体这一概念,那么接下来需要了解的就是值对象、唯一标识。值对象,值就是数字1、2、3,字符串“1”,“2”,“3”,值时对象的特征,对象是一个事物的具体描述...

MrYuZixian
昨天
6
0
数据库中间件MyCat

什么是MyCat? 查看官网的介绍是这样说的 一个彻底开源的,面向企业应用开发的大数据库集群 支持事务、ACID、可以替代MySQL的加强版数据库 一个可以视为MySQL集群的企业级数据库,用来替代昂贵...

沉浮_
昨天
6
0
解决Mac下VSCode打开zsh乱码

1.乱码问题 iTerm2终端使用Zsh,并且配置Zsh主题,该主题主题需要安装字体来支持箭头效果,在iTerm2中设置这个字体,但是VSCode里这个箭头还是显示乱码。 iTerm2展示如下: VSCode展示如下: 2...

HelloDeveloper
昨天
7
0
常用物流快递单号查询接口种类及对接方法

目前快递查询接口有两种方式可以对接,一是和顺丰、圆通、中通、天天、韵达、德邦这些快递公司一一对接接口,二是和快递鸟这样第三方集成接口一次性对接多家常用快递。第一种耗费时间长,但是...

程序的小猿
昨天
10
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部