嘿,我想要一个通用模型/实体类,它可以通过 db 中 long 元素类型的 id 下载。方法是这样的:
public class GenericModel {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
public Long id;
public static GenericModel getBy(Long id) {
return JPA.em().find(GenericModel.class, id);
}
}
但是在将由子模型类扩展的通用模型中,我必须动态声明实体类名称才能在数据库中找到。
我想要一个通用的实体类,其中我将有像 getById() 这样的通用方法。并且该通用类将由具体实体类扩展。我不必在每个模型类中编写相同的方法,因为它将继承自泛型类 –
我怎样才能做到这一点?
这是我的 DAO 接口(interface)。我不太确定:
public interface GenericModelDao<T> {
public void add(T entityClass);
public void update(T entityClass);
public void delete(long id);
public T get(long id);
public List<T> get();
}
还有这个接口(interface)的我的DAO实现类
@Repository
public class GenericModelDaoImpl <T extends GenericModel> implements GenericModelDao {
public Class<T> entityClass;
GenericModelDaoImpl(){
setEntityClass(((Class) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0]));
}
public void setEntityClass(Class<T> entityClass) {
this.entityClass = entityClass;
}
@Autowired
private SessionFactory sessionFactory;
private Session getCurrentSession() {
return sessionFactory.getCurrentSession();
}
@Override
public T get(long id) {
return (T) getCurrentSession().get(entityClass, id);
}
@Override
public void delete(long id) {
T entityClass = get(id);
getCurrentSession().delete(entityClass);
}
@Override
public List<T> get() {
return getCurrentSession().createQuery("from " + entityClass ).list();
}
@Override
public void add(Object entityClass) {
getCurrentSession().save(entityClass);
}
@Override
public void update(Object entityClass) {
getCurrentSession().update(entityClass);
}
}
还有我的 GenericModel 类
@MappedSuperclass
public abstract class GenericModel<T extends GenericModel> {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
public Long id;
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
}
请再给我一些额外的帮助:D
最佳答案
您不能在静态方法中使用泛型参数(有关更多详细信息,请参阅 https://stackoverflow.com/a/936951/1643132),因此您必须从 getBy() 方法中删除 static 关键字。
作为第一步,您可以在 GenericModel 类中引入泛型:
public abstract class GenericModel<T extends GenericModel> {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
public Long id;
public T getBy(Long id) {
return JPA.em().find(????, id);
}
}
问题是,像 T.class 这样的东西是行不通的(在 getBy() 方法中)。 感谢 java.lang.reflect.ParameterizedType,您可以在运行时检索 T 类。因此,将您的 GenericModel 更新为:
@MappedSuperclass
public abstract class GenericModel<T extends GenericModel> {
private Class<T> entityClass;
GenericModel(){
entityClass = ((Class) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0]);
}
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
public Long id;
public T getBy(Long id) {
return JPA.em().find(entityClass, id);
}
public Long getId() {
return id;
}
}
您的子实体可能如下所示:
@Table(name="child_model")
@javax.persistence.Entity
public class ChildModel extends GenericModel<ChildModel> {
@Column
private String data;
public String getData() {
return data;
}
public void setData(String data) {
this.data = data;
}
}
关于java - 使用 dao 接口(interface)和实现实现通用抽象实体类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26782583/