я использовать JPA затмение TOPLINK & EJBJPA отключить автоматическое сохранение
каждый раз, когда я получить объект из базы данных, то изменить некоторые данные внутри него,
базы данных (MYSQL) автоматически менять тоже не предаю или сделать что-то
Пример:
Player p = em.findById(1);
p.setName(newName);
// i do nothing , but database automaticly change
я уже прочитал соответствующий вопрос здесь, но я до сих пор не могу понять его
я думаю, что я должен отделить сущность, но я не знаю, как это сделать, потому что
я класс GenericDAO генерируется из NetBeans
GenericDAO (генерируется от NetBeans)
public abstract class GenericDAO<T> {
private Class<T> entityClass;
public GenericDAO(Class<T> entityClass) {
this.entityClass = entityClass;
}
protected abstract EntityManager getEntityManager();
public void insert(T entity) {
getEntityManager().persist(entity);
}
public void edit(T entity) {
getEntityManager().merge(entity);
}
public void delete(T entity) {
getEntityManager().remove(getEntityManager().merge(entity));
}
public T findById(Object id) {
return getEntityManager().find(entityClass, id);
}
public List<T> findAll() {
javax.persistence.criteria.CriteriaQuery cq = getEntityManager().getCriteriaBuilder().createQuery();
cq.select(cq.from(entityClass));
return getEntityManager().createQuery(cq).getResultList();
}
public List<T> findRange(int[] range) {
javax.persistence.criteria.CriteriaQuery cq = getEntityManager().getCriteriaBuilder().createQuery();
cq.select(cq.from(entityClass));
javax.persistence.Query q = getEntityManager().createQuery(cq);
q.setMaxResults(range[1] - range[0] + 1);
q.setFirstResult(range[0]);
return q.getResultList();
}
public int count() {
javax.persistence.criteria.CriteriaQuery cq = getEntityManager().getCriteriaBuilder().createQuery();
javax.persistence.criteria.Root<T> rt = cq.from(entityClass);
cq.select(getEntityManager().getCriteriaBuilder().count(rt));
javax.persistence.Query q = getEntityManager().createQuery(cq);
return ((Long) q.getSingleResult()).intValue();
}
}
DaoPlayer
@Local
public interface DaoPlayer{
void insert(Player player);
void edit(Player player);
void delete(Player player);
Player findById(Object id);
List<Player> findAll();
List<Player> findRange(int[] range);
int count();
ImplPlayer
@Stateless
public class ImplPlayer extends GenericDAO<Player> implements DaoPlayer{
@PersistenceContext(unitName = "MonsterPuzzle")
private EntityManager em;
@Override
protected EntityManager getEntityManager() {
return em;
}
public ImplPlayer() {
super(Player.class);
}
}
Мой вопрос
- как отключить JPA автоматически сохранить в базе данных?
- (Потому что я думаю, что мне нужно отсоединить), как отсоединить объект от GenericDAO?
где я должен разместить аннотацию сэр? в интерфейсе в классе реализации или в GenericDao? Я уже тестировал в интерфейсе, не работает, но я снова проверю –
В классе реализации. – SJha