分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 软件开发

hibernate hql语句 注意事项

发布时间:2023-09-06 01:46责任编辑:熊小新关键词:暂无标签

现在有实体类 Student 和User 。

public class Student{

  private String id;

  private Sting classRoom;

  private User user;

@Id
@GeneratedValue(generator = "paymentableGenerator")
@GenericGenerator(name = "paymentableGenerator", strategy = "uuid")
@Column(name ="ID",nullable=false,length=36)
public String getId(){
??return this.id;
}
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "USER")
@ForeignKey(name="null")
public USER getUser() {
??return user;
}
public void setUser(User user) {
??this.user = user;
}
……

}

public class User{

  private String id;

  private String name;

  private String password;

  ……

}

如果 你不用select 直接 “from Student ”查找 

hql语句 :“from Student where user=‘123456’”

那么where 后面 直接加 “where user=‘123456‘”  (123456是User表记录的id)。

如果你要用select “select classRoom…”查找

hql语句 :"select “select classRoom,user.name as user from Student where uder.id=‘123456‘"

那么where语句已经select中 的user已经是个对象了要加 .? (123456是User表记录的id)。

你用了 select 了,那你就别执着用hibernate的hql了 ,因为你得到的结果 也不再是实体类,获取结果也不能用 List<Studet>了,变成了List<Object[]>。。。

很难受 - - 还不如直接用sql查,获取结果也是List<Object[]>

hibernate hql语句 注意事项

原文地址:https://www.cnblogs.com/xlj227/p/8615945.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved