hibernate,hql中的sql(nativequery)

xxls0lw8  于 2021-08-09  发布在  Java
关注(0)|答案(1)|浏览(433)

我从冬眠开始。我现在正在尝试hql中的sql。我看到了一个我想重新创建的代码示例,但是我的输出结果不同。要在hql中使用sql,那个人说,如果你只想使用几个列,你需要使用一个Map来获得某些列(这样我就可以´这里不能简单地使用加法)。我的学生桌上有希德,斯奈姆,斯马克。现在我只想检索学生的名字(sname)和他们的分数(smarks)。问题是,我只得到“null”作为名称和标记的值,而对象向我显示正确的值:
控制台输出:休眠:选择sname,smarks from student
{sname=nameless fool number 1,smarks=65}空:空
代码:

NativeQuery querySQL2 = session.createNativeQuery("SELECT sName,sMarks "
            +                                   "FROM student");
querySQL2.setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP);
List students = querySQL2.getResultList();
for (Object o : students)
{
    System.out.println(o);
    Map m = (Map)o;
    System.out.println(m.get("sName") + " : " + m.get("sMarks"));
}

为什么我要用syso(o)得到正确的对象,而用syso(m.get(“…”)只得到null?提前谢谢!

dz6r00yl

dz6r00yl1#

实际上你已经回答了你的问题 {SNAME=Nameless fool number 1, SMARKS=65} . hibernate将列名转换为大写。

相关问题