我有下一个错误:nested exception is org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role: com.example.Model.entities, could not initialize proxy - no Session
我的Model
实体:
class Model {
...
@OneToMany(fetch = FetchType.LAZY, mappedBy = "model", orphanRemoval = true)
@Cascade(CascadeType.ALL)
@Fetch(value = FetchMode.SUBSELECT)
public Set<Entity> getEntities() {
return entities;
}
public void addEntity(Entity entity) {
entity.setModel(this);
entities.add(entity);
}
}
我有一个服务类:
@Service
@Transactional
class ServiceImpl implements Service {
@Override
public void process(Model model) {
...
model.addEntity(createEntity());
...
}
}
我正在使用其他服务方法调用服务:
@Override
@JmsListener(destination = "listener")
public void handle(final Message message) throws Exception {
Model model = modelService.getById(message.getModelId());
serviceImpl.process(model);
modelService.update(model);
}
但是当我尝试调用此方法时,我在第entities.add(entity);
行上遇到异常,当我在getEntities()
上调用model
时,也会发生同样的异常。
我已经检查了事务管理器并且它已正确配置,并且此步骤中存在事务。此外,我已经检查了与此异常相关的stackoverflow上的大量答案,但没有任何用处。
它可能是什么原因?
答案 0 :(得分:8)
模型似乎是一个独立的实体。
尝试合并并对合并实例执行操作:
@Override
public void process(Model model) {
...
Model mergedModel = session.merge(model);
mergedModel.addEntity(createEntity());
...
}
答案 1 :(得分:4)
正如@Maciej Kowalski在第一次@Transactional
读取已经处于无人状态的model
之后提到的那样,并打电话从另一个entities
方法获取@Transactional
LazyInitializationException
失败。
我已经改变了我的服务,以便在同一个交易中从数据库中获取model
:
@Service
@Transactional
class ServiceImpl implements Service {
@Override
public void process(long modelId) {
...
Model model = modelDao.get(modelId);
model.addEntity(createEntity());
...
}
}
现在一切都按预期工作了。