gpt4 book ai didi

java - @Transactional 在服务中的使用,当方法仅从数据库中获取数据时。

转载 作者:行者123 更新时间:2023-11-30 10:25:27 24 4
gpt4 key购买 nike

我刚找到一段代码,如下所示:

@Transactional
public List<Foo> giveMeFooMatchingSomeConstraints(Long param1, String param2) {
List<Bar> bars = barDao.findBars(param1, param2);
List<Foo> foos = fooDao.findFoosByBarIds(barService.getIds(bars));
return foos;
}

我很好奇在方法只获取数据而不修改它们的情况下使用@Transactional 的目的是什么。像上面这样的方法可以吗?

最佳答案

是的,当您不使用 Open*InView 并在您的方法中处理惰性关系时,这很有意义。

假设我们将这些实体与一对多关系绑定(bind)在一起:

@Entity(name = "user")
static class User extends AbstractPersistable<String> {
private String username;

@OneToMany(cascade = CascadeType.ALL, orphanRemoval = true) //by default fetching is lazy
@JoinColumn(name = "user_id", foreignKey = @ForeignKey(name = "fk_user_roles"))
private Set<Role> roles = new HashSet<>();

public Set<Role> getRoles() {
return this.roles;
}
}

@Entity(name = "role")
static class Role extends AbstractPersistable<String> {
private String name;

private Role() {
}

public Role(String name) {
this.name = name;
}

public String getName() {
return this.name;
}
}

访问它们的存储库:

interface UserDao extends JpaRepository<User, String> {}

和一些数据操作服务——检索所有用户,遍历他们并获取所有角色:

@Service
static class UserService {
private final UserDao userDao;

UserService(UserDao userDao) {
this.userDao = userDao;
}

@Transactional // <---
public Set<String> findUserRoles() {
final List<User> users = this.userDao.findAll();
return users.stream()
.flatMap(user -> user.roles.stream())
.map(Role::getName)
.collect(Collectors.toSet());
}
}

删除 @Transactional 以查看带有 no Session 消息的 LazyInitializationException,因为没有人打开它。

为了避免在这种情况下造成混淆,最好将事务明确标记为只读:

@Transactional(readOnly = true)

所以读者会知道这个方法无意修改任何数据,但仍然需要事务( session )。

Full example .

关于java - @Transactional 在服务中的使用,当方法仅从数据库中获取数据时。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46193254/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com