OpenJPA 使用 NativeQuery 和 @SqlResultSetMapping 返回不正确的结果

问题描述

我的 sqlresultsetmapping

@sqlresultsetmapping (
    name = Barcode.SEARCH_MAP,entities = {
        @EntityResult (entityClass = Barcode.class),@EntityResult (entityClass = User.class),@EntityResult (entityClass = LdapAccount.class)
    }
)

我的查询

SELECT nbc.*,u.*,l.* 
FROM db.barcodes nbc LEFT JOIN reports.user u ON nbc.userid = u.userid
                     LEFT JOIN reports.ldap_account l ON u.id = l.user_id
WHERE UPPER(u.userid) LIKE UPPER('username')
UNION 
SELECT nbc.*,l.* 
FROM db.barcodes nbc RIGHT JOIN reports.user u ON nbc.userid = u.userid
                     RIGHT JOIN reports.ldap_account l ON u.id = l.user_id  
WHERE UPPER(l.username) LIKE UPPER('username')

我的代码

Query query = em.createNativeQuery (searchQuery.toString (),Barcode.SEARCH_MAP);
List<Object[]> tmp = (List<Object[]>) query.getResultList ();

for (Object[] o : tmp) {
    Barcode     nb   = (Barcode) o[0];
    User        user = (User) o[1];
    LdapAccount la   = (LdapAccount) o[2];
}

如果我在数据库上运行查询,结果是正确的。但是 OpenJPA 没有返回正确的数据。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...