将对象数组转换为JPA实体数组?

时间:2012-04-13 11:55:51

标签: java jpa

每次尝试从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.

3 个答案:

答案 0 :(得分:1)

您可以尝试TypedQuery获取实体列表,而无需显式转换&amp;防止例外。

TypedQuery<QuickLaunch> listQL = em.createNamedQuery("QuickLaunch.getQuickLaunch", QuickLaunch.class);

List<QuickLaunch> products = listQL .getResultList();

此外,更改了查询名称以更有意义的方式标识其类或结果类型。

答案 1 :(得分:1)

好吧......我想我找到了答案。它受到了这篇文章的启发......

  

https://stackoverflow.com/a/8060077/729820

我基本上这样做

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()]);         
    }

所有异常似乎都清楚了。 谢谢你的帮助。

答案 2 :(得分:1)

这与JPA而不是Java有关,因为它不会将Object []强制转换为QuickLaunch []。你能否使用Object数组而不是QuickLaunch []数组?