Java - 方法中的对象参数必须有@Entity 注释
Java - Object parameter in method must have @Entity annotation
我想为实体 class 创建一个远程 EJB。有没有一种方法可以用一个参数来实现一个方法,该方法是一个 class 的对象,该对象专门具有 @Entity 注释?这样做的目的是为我的所有实体创建一个 bean。
示例:
public void save(Entity ent){
em.persist(ent);
}
如果所有实体只有 1 个 ejb,当您必须以特殊方式处理其中一些实体时,您很快就会 运行 遇到问题。
但是您可以使用抽象的超级 ejb 这样做,并且每个实体仍然有 1 个 ejb,但创建起来非常容易。您仍然可以覆盖默认的继承方法。
public abstract class AbstractEjb<T> {
private Class<T> entityClass;
public AbstractEjb(Class<T> entityClass) {
this.entityClass = entityClass;
}
protected abstract EntityManager getEntityManager();
public void create(T entity) {
getEntityManager().persist(entity);
}
public void edit(T entity) {
getEntityManager().merge(entity);
}
public void remove(T entity) {
getEntityManager().remove(getEntityManager().merge(entity));
}
public T find(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();
}
}
要为实体实施,只需执行
@Stateless
public class TestEjb extends AbstractEjb<TestEntity> {
@PersistenceContext(unitName = "...")
private EntityManager em;
public TestEjb() {
super(TestEntity.class);
}
public EntityManager getEntityManager() {
return em;
}
}
来源:从 Netbeans 中的实体 类 生成 JSF 页面。
我想为实体 class 创建一个远程 EJB。有没有一种方法可以用一个参数来实现一个方法,该方法是一个 class 的对象,该对象专门具有 @Entity 注释?这样做的目的是为我的所有实体创建一个 bean。
示例:
public void save(Entity ent){
em.persist(ent);
}
如果所有实体只有 1 个 ejb,当您必须以特殊方式处理其中一些实体时,您很快就会 运行 遇到问题。
但是您可以使用抽象的超级 ejb 这样做,并且每个实体仍然有 1 个 ejb,但创建起来非常容易。您仍然可以覆盖默认的继承方法。
public abstract class AbstractEjb<T> {
private Class<T> entityClass;
public AbstractEjb(Class<T> entityClass) {
this.entityClass = entityClass;
}
protected abstract EntityManager getEntityManager();
public void create(T entity) {
getEntityManager().persist(entity);
}
public void edit(T entity) {
getEntityManager().merge(entity);
}
public void remove(T entity) {
getEntityManager().remove(getEntityManager().merge(entity));
}
public T find(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();
}
}
要为实体实施,只需执行
@Stateless
public class TestEjb extends AbstractEjb<TestEntity> {
@PersistenceContext(unitName = "...")
private EntityManager em;
public TestEjb() {
super(TestEntity.class);
}
public EntityManager getEntityManager() {
return em;
}
}
来源:从 Netbeans 中的实体 类 生成 JSF 页面。