首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >@Transactional(isolation = Isolation.SERIALIZABLE)如何只锁定几行

@Transactional(isolation = Isolation.SERIALIZABLE)如何只锁定几行
EN

Stack Overflow用户
提问于 2018-04-24 19:31:02
回答 1查看 601关注 0票数 0

我有一个类似这样的方法:

代码语言:javascript
复制
@Transactional(isolation = Isolation.SERIALIZABLE)
public default Student doSomething(Student student) {
  School sch = student.getSchool(); // @JoinColumn's
  List students = sch.getAllStudents();
  List names = getAllNames(students); // stream.map to names or something similar.
  if(!names.contains(student.name)) {
    save(student);
}
}

正如我们从代码片段中看到的,我们有一个学生。我们从学生那里得到学校,然后从学校得到所有的学生。然后我们得到他们的名字,如果学生不在那里,我们就添加它-否则就不添加。从该代码中,我预计只有在为同一学校添加两个线程时,才会出现可序列化的异常。但我有“无法序列化访问”,即使我们添加两个不同的学校的学生。spring/hibernate锁定机制不能处理这种情况吗?:(它不应该只锁定方法期间使用的表中的行吗?请在这个特定的案例中提供帮助。提前谢谢。

EN

回答 1

Stack Overflow用户

发布于 2018-04-24 19:46:36

我不是100%确定,但是Isolation.SERIALIZABLE不是锁定了所有表并阻止您添加学生吗?

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50000614

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档