Код ниже - это то, что Spring Roo генерирует по умолчанию, EntityManager внедряется в POJO модели вашего домена с остальными методами управления сущностью (сохранение, обновление, удаление, findXXX, .. .).
Возможно, это более объектно-ориентированный подход (в отличие от модели анемичной области ), но я не понимаю:
Есть ли производительность , когда EntityManager внедряется в каждую сущность (представьте, что вы извлекаете 1000 сущностей из базы данных)
Не должно ли управление транзакциями (аннотации @Transactional) перейти на уровень обслуживания? (представьте, что вы хотите работать с двумя различными объектами атомарным способом).
Можете ли вы вспомнить другие плюсы / минусы этого кода по сравнению с классическим уровнем DAO?
Код выглядит следующим образом (некоторые методы удалены для ясности):
@Configurable
@Entity
@RooJavaBean
@RooToString
@RooEntity
public class Answer {
@PersistenceContext
transient EntityManager entityManager;
@Transactional
public void persist() {
if (this.entityManager == null) this.entityManager = entityManager();
this.entityManager.persist(this);
}
@Transactional
public void remove() {
if (this.entityManager == null) this.entityManager = entityManager();
if (this.entityManager.contains(this)) {
this.entityManager.remove(this);
} else {
Answer attached = Answer.findAnswer(this.id);
this.entityManager.remove(attached);
}
}
@Transactional
public Answer merge() {
if (this.entityManager == null) this.entityManager = entityManager();
Answer merged = this.entityManager.merge(this);
this.entityManager.flush();
return merged;
}
public static final EntityManager entityManager() {
EntityManager em = new Answer().entityManager;
if (em == null) throw new IllegalStateException("Entity manager has not been injected (is the Spring Aspects JAR configured as an AJC/AJDT aspects library?)");
return em;
}
public static long countAnswers() {
return entityManager().createQuery("SELECT COUNT(o) FROM Answer o", Long.class).getSingleResult();
}
public static List<Answer> findAllAnswers() {
return entityManager().createQuery("SELECT o FROM Answer o", Answer.class).getResultList();
}
...
}