在Hibernate中使用native-sql - 如何处理结果

RKo*_*dla 4 hibernate

我有几个表,我不能使用hibernate映射来定义关联(或者我不知道如何做它们)..所以我决定在尝试查询连接结果时使用nativesql ..查询是这样的..

 String sql = "SELECT p.lastName, p.firstName, p.middleName, p.deactivateDate, p.id, p.userId, p.userRole, TO_CHAR(MAX(au.timestamp),'MM/DD/YYYY') as \"last_Login\", ROUND(SYSDATE-MAX(au.timestamp))as \"days_Elapsed\" 
              FROM LLPersonnel p LEFT OUTER JOIN LoginAudit au ON p.userId = au.userAccount AND UPPER(au.operation) = 'SUCCESS'" 
              WHERE p.deactivateDate is null AND p.userRole is not null GROUP BY p.lastName, p.firstName, p.middleName, p.deactivateDate, p.id, p.netId, p.llRole" 
              ORDER BY 1, 2, 3";

    SQLQuery qry = sessionFactory.getCurrentSession().createSQLQuery(sql);
            qry.list();
Run Code Online (Sandbox Code Playgroud)

问题是qry.list()返回对象数组,我似乎无法将其强制转换为任何其他对象.我的意思是我用这样的构造函数创建了一个虚拟对象.

DummyObject(lastName,firstName,middleName,deactivatedate,id,userId,userRole,last_Login,days_Elapsed)

并尝试将列表像...

列表dummyList = Listqry.list();

但这不起作用..当我尝试从dummyList访问DummyObject时,我得到的casr对象不能用于DummyObject异常.

Nor*_*man 8

该代码应该返回一个Object []列表.您可以创建一个类并调用.addEntity(),它将为您填充实体.

或者,如果您愿意,您可以自己操作每行的Object []数组.如果您事先知道数据类型,则可以使用字符串,整数等.

我经常这样做:

List<Object[]> list = (List<Object []>) q.list();
for (Object[] row : list) {
    String lastName = (String) row[0];
    ...
}
Run Code Online (Sandbox Code Playgroud)