我以前只使用反射来做动态获取类和设置字段值。我的Google搜索向我展示了我还可以使用反射进行动态类型转换?
我的代码如下:
import entity.Shipvia;
import entity.Route;
import java.lang.reflect.Field;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.Persistence;
import javax.persistence.Query;
public class RetrieveResultList {
public static List retrieveResultList(String tablename) {
EntityManager entityManager = Persistence.createEntityManagerFactory("EntityLibraryPU").createEntityManager();
Query query = entityManager.createNamedQuery(tablename + ".findAll");
List<Shipvia> resultList = query.getResultList();
return resultList;
}
}
我正在使用此方法动态检索数据库表中的结果。因为表名总是不同的,所以我不能拥有List,因为每个表都不同。
我如何将我传入的tablename字符串转换为List的类型?
答案 0 :(得分:5)
你不能这样做,即使你可以,它也没用,因为所有的泛型信息在编译时从Java代码中删除,只有强制转换会存在,而你将使用反射,就没有强制转换要做。
您可以做的最接近的事情是,而不是发送字符串发送类对象。调用者代码必须说出它想要的类(调用者可能知道它正在使用什么类型的对象),并且您将使用它来使列表具有正确的通用。
一个非常简单的实现是这样的:
List<Shipvia> shipvias = RetrieveResultList.retrieveResultList( Shipvia.class );
实施可能是这样的:
public class RetrieveResultList {
private static final EntityManagerFactory FACTORY = Persistence.createEntityManagerFactory("EntityLibraryPU");
public static <T> List<T> retrieveResultList(Class<T> type) {
EntityManager entityManager = FACTORY.createEntityManager();
String tablename = type.getName(); // figure out table name from **type**
Query query = entityManager.createNamedQuery(tablename + ".findAll");
List<T> resultList = query.getResultList();
entityManager.close();
return resultList;
}
}
然后你应该有类似于你正在寻找的东西。
另外,不要在每次调用此方法时创建实体管理器工厂,实体管理器工厂必须是项目中的单件,因为它是一个非常昂贵的对象来创建。您还应该在离开方法之前关闭您创建的 EntityManager 。