【发布时间】:2017-05-22 00:24:45
【问题描述】:
我正在使用 Spring boot 作为带有 spring 数据的 rest 后端系统, 我有三个主要层(控制器、服务、dao)。
我用@Transactional 注释了服务类,并在其中一种方法中检索了一些与其他实体具有@ManyToMany 关系的实体。
我只想获得主要实体,我依赖于 @ManyToMany 的懒惰。
问题是从服务返回到控制器后,当我在(许多)端点击 sql 语句并检索集合时,好像事务仍在运行!
@SpringBootApplication
@ComponentScan(value = { "net.pd.ethraa" })
@EnableJpaRepositories(basePackages = { "net.pd.ethraa.dao" })
@EntityScan(basePackages = "net.pd.ethraa.common.model")
@EnableTransactionManagement
public class EthraaApplication extends SpringBootServletInitializer {
}
@RequestMapping(path = "/get/{id}", method = RequestMethod.GET)
public Account getAccount(@PathVariable("id") Long id) {
Account account = accountService.find(id);
for (Permission p : account.getPermissions()) {
System.out.println(p.getName());
}
return account;
}
@Service
@Transactional
public class AccountServiceImpl implements AccountService {
@Override
public Account find(Long id) {
return accountDao.findOne(id);
}
}
@Repository
public interface AccountDao extends CrudRepository<Account, Long> {}
@Entity
@Table(name = "ACCOUNT", uniqueConstraints = @UniqueConstraint(columnNames = { "mobile", "email" }))
public class Account extends BaseEntity {
@ManyToMany
@JoinTable(name = "ACCOUNT_PERMISSION")
private List<Permission> permissions;
}
我的期望是当我在服务之外点击集合时,它应该在事务边界之外并给出惰性异常但它没有?
【问题讨论】:
标签: hibernate spring-boot spring-data lazy-loading spring-transactions