hibernate查询的方式和变量
1、实体查询:
hql="FROM User";
List list= session.createQuery(hql).list();
for(Object obj:list){
System.out.println(obj);
}
【注意】:HQL语句中关键字不区分大小写,但是实体类和对象属性要区分大小写
2、查询某个对象的某个属性
hql="SELECT name FROM User where id=1";
方式一:
Object name= session.createQuery(hql).list().get(0);
System.out.println(name);
这种方式不被推荐,当如果id=0的User对象不存在是,使用get(0)会抛出异常,我们通常使用下面这种方式
方式二:通过uniqueResult()方法,该方法返回一个Object对象,如果对象不存在则返回null,如果返回值不唯一,则抛出异常
1 Object name= session.createQuery(hql).uniqueResult();
2 System.out.println(name)
3、查询其中几列数据,返回一个数组
hql="SELECT id,name FROM User";
List list= session.createQuery(hql).list();
for(Object obj:list){
System.out.println(Arrays.toString((Object[])obj));
}
list()返回的是一个List<Object>对象
4、查询其中几列数据,返回一个实体类
hql="SELECT new User(id,name) FROM User";
List<User> list= session.createQuery(hql).list();
for(User user:list){
System.out.println(user);
}
HQL通过new的方式可以返回一个新的实体类,比如说上面通过new User(id,name)方式将id,name返回给User,要求User必须包含一个相对应的构造函数,否则会抛出异常,同时我们还有应该给User指定一个默认的构造函数,否则使用From User也会抛出异常,因为这种方式采用的是默认构造。值得注意的是,如果使用的新构造对象,那么处理指定的属性会被赋予新值外,其它属性均为默认值。
5、WHER、GROUP BY、HAVING和ORDER综合使用
hql="SELECT age, COUNT(age) num FROM User WHERE age>10 GROUP BY age HAVING COUNT(age)>1 ORDER BY num DESC";
在HAVING中,不能使用别名num,但在ORDER BY中可以使用别名num
6、使用占位符"?"
hql="FROM User where id=?";
User user= (User)session.createQuery(hql)
.setParameter(0, 2)
.uniqueResult();
System.out.println(user);
Hibernate和JDBC占位符的区别:在Hibernate占位符下标从0开始,在JDBC中的占位符下标从1开始
7、使用命名参数
hql="FROM User where id=:id";
User user= (User)session.createQuery(hql)
.setParameter("id", 2)
.uniqueResult();
System.out.println(user);
使用参数的方式,在HQL中在参数前面需要加上冒号
8、使用集合或数组参数
hql="FROM User where id IN (:ids)";
List<User> list= session.createQuery(hql)
.setParameterList("ids", new Object[]{1,3,4})
.list();
for (User user : list) {
System.out.println(user);
}
9、使用命名方式查询
如果我们将HQL代码写在类中,那么编译后我们非常难以维护,为了后期代码的可维护行,我们需要将HQL代码写在对应类的.hbm.xml文件中,例如:
<query name="queryUserRanage">
FROM User WHERE id BETWEEN ? AND ?
</query>
在Java代码中

Query query=session.getNamedQuery("queryUserRanage");
List<User> list=query
.setParameter(0, 10)
.setParameter(1, 20)
.list();
for(User user:list){
System.out.println(user);
}

通常我们使用参数的方式,这样可以很直观知道每个参数的作用
<query name="queryUserRanage">
FROM User WHERE id BETWEEN :minId AND :maxId
</query>
但是如果在SQL语句中存在>、<等xml中特殊字符,这些字符在xml中都有特殊的意义,所有我们不能直接这样写
【Error】
<query name="queryUserRanage">
FROM User WHERE id > :minId AND id< :maxId
</query>
【Right】
<query name="queryUserRanage">
FROM User WHERE id > :minId AND < :maxId
</query>
虽然上面的方式我们可以正确执行,但是代码显示不够友好,所有我们推荐使用下面的一种方式
<query name="queryUserRanage">
<![CDATA[FROM User WHERE id > :minId AND < :maxId]]
</query>
CDATA代码块说明在代码中的语句不需要转义,我们一个HQL都推荐用CDATA块来包裹着
hibernate查询的方式和变量的更多相关文章
- hibernate查询方式
hibernate查询方式:1.本地SQL查询 2.HQL查询 3.QBC查询 HQL查询:是面向对象的查询语言,是使用最广的一种查询方法 QBC查询:Query by Criteria是一套接口来实 ...
- (十)Hibernate 查询方式
所有项目导入对应的hibernate的jar包.mysql的jar包和添加每次都需要用到的HibernateUtil.java 第一节:Hibernate 查询方式简介 1,导航对象图查询方式: 2 ...
- 六种方式实现hibernate查询
最近在学习Hibernate的基本内容,刚好在项目中有用到,基本上都是用到哪就学哪. 今天看看六种方式实现hibernate查询......... 分别是HQL查询,对象化查询Criteria方法,动 ...
- Hibernate查询方式(补)
-----------------siwuxie095 Hibernate 查询方式 1.对象导航查询 根据已经加载的对 ...
- Redis查询&JDBC查询&Hibernate查询方式的效率比较...
比较三种查询方式查询效率对比...我是用的JavaWeb的方式通过通过JSP页面查询的填写查询的参数...给予反馈.... 整个demo的下载地址:http://files.cnblogs.com/f ...
- Hibernate查询的六种方式
Hibernate查询的六种方式 分别是HQL查询,对象化查询Criteria方法,动态查询DetachedCriteria,例子查询,sql查询,命名查询. 如果单纯的使用hibernate ...
- Hibernate学习10——Hibernate 查询方式
本章主要是以查询Student的例子: Student.java: package com.cy.model; public class Student { private int id; priva ...
- Hibernate的查询的方式
Hibernate的查询的方式 在Hibernate中提供了很多种的查询的方式.Hibernate共提供了五种查询方式. Hibernate的查询方式:OID查询 OID检索:Hibernate根据对 ...
- Hibernate 查询方式、JPA查询方式
hibernate 查询方式: OID 查询 对象导航查询 HQL 方式查询 QBC方式查询 原生SQL方式查询 JPA 查询方式: OID 查询 对象导航查询 JPQL 方式查询 CriteriaB ...
随机推荐
- shell 比较运算符
运算符 描述 示例 文件比较运算符 -e filename 如果 filename 存在,则为真(不管文件或目录) [ -e /var/log/syslog ] -d filename 如果 fi ...
- delphi通过Idhttp和php交互
最近需要做delphi和php交互的方法: 就把这2个方法写了下 一,Get方法 const Url = 'http://www.cnblogs.com'; procedure TForm1.Butt ...
- Android之史上最全最简单最有用的第三方开源库收集整理
Android开源库 自己一直很喜欢Android开发,就如博客签名一样, 我是程序猿,我为自己代言 . 在摸索过程中,GitHub上搜集了很多很棒的Android第三方库,推荐给在苦苦寻找的开发者, ...
- 常用的SQL 总结
1.去重 SELECT * FROM my where id in(SELECT MAX(id) from my GROUP BY id,iid,pid)//取 id,iid,pid重复的最大值
- MVC中使用showModalDialog
1.mvc中使用模态对话框用于修改数据,如果第一次修改过后刷新页面,第二次修改时显示内容依然是第一次修改之前的,这里用js中的Math.Random()解决 Views: <%: Html.Ac ...
- jQuery对象和DOM对象的相互转化实现代码
jQuery对象和DOM对象相互转化 jQuery对象和DOM对象 jQuery对象就是通过jQuery包装DOM对象后产生的对象.jQuery对象是jQuery独有的,其可以使用jQuery里的方法 ...
- JavaUtil_07_HttpUtil_使用Hutool 封装的 HttpUtil
二.参考资料 1.[Hutool]Hutool工具类之Http工具——HttpUtil
- (转)python调取C/C++的dll生成方法
本文针对Windows平台下,python调取C/C++的dll文件. 1.如果使用C语言,代码如下,文件名为test.c. __declspec(dllexport) int sum(int a,i ...
- 【leetcode刷题笔记】Best Time to Buy and Sell Stock III
Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...
- 【二叉树的递归】04找出二叉树中路径和等于给定值的所有路径【Path Sum II】
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 给定一个二叉树和一个和,判断这个树 ...