每次我试图从从jpa调用中拉回的实体列表中获取实体数组时,都会得到一个强制转换异常。例如。
QuickLaunch[] qLaunchArr = null;
List<QuickLaunch> listQL = null;
try
{
System.out.println("testing 1..2..3");
//qLaunchArr
listQL = emf.createNamedQuery("getQuickLaunch").getResultList();
Object[] objArr = listQL.toArray();
//System.out.println(listQL.size());
qLaunchArr = (QuickLaunch[]) listQL.toArray();
}
catch (Exception e)
{
System.out.println("Bull Hockey!!!! I can't believe it's not butter!: "+e.toString());
}
[Ljava.lang.Object; incompatible with [Lcom.upmc.esdm.messaging.entities.QuickLaunch;在我的服务器日志里..。(我使用的是WID),我也得到了这个异常...
commonj.connector.runtime.DataHandlerException: CWLAP0507E: The response bean class for java class method GetAllQuickLaunchComponents cannot be created. Reason java.lang.IllegalArgumentException: argument type mismatch.发布于 2012-04-13 20:48:07
您可以尝试使用TypedQuery来获取实体列表,而无需显式强制转换和防止异常。
TypedQuery<QuickLaunch> listQL = em.createNamedQuery("QuickLaunch.getQuickLaunch", QuickLaunch.class);
List<QuickLaunch> products = listQL .getResultList();此外,更改了查询名称,以便以更有意义的方式标识其类或结果类型。
发布于 2012-04-13 21:33:11
好吧..。我想我找到答案了。它的灵感来自于这篇文章。
我基本上就是这么做的
try
{
System.out.println("testing 1..2..3");
listQL = emf.createNamedQuery("getQuickLaunch").getResultList();
System.out.println("What is the size of this list: number "+listQL.size());
qLaunchArr = listQL.toArray(new QuickLaunch[listQL.size()]);
}所有的例外似乎都被清除了。谢谢你们的帮助。
发布于 2012-04-13 21:34:58
这不是与JPA有关,而是与Java有关,因为它不会将Object[]转换为QuickLaunch[]。可以不使用Object数组而不使用QuickLaunch[]数组吗?
https://stackoverflow.com/questions/10140348
复制相似问题