Hibernate 查询:HQL查询(Hibernate Query Languge)
HQL是一种面向对象的查询语言,其中没有表和字段的概念,只有类,对象和属性的概念。
使用HQL查询所有学生:
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String hql = "from Student";
Query query = session.createQuery(hql);
List<Student> students = query.list();
System.out.println(students);
session.getTransaction().commit();
}
字符串 hql 是一条HQl语句,其中Student是指类名而不是表名,该语句查询Student类所映射的表的所有信息。
使用HQL查询时需要使用到org.hibernate.Query接口,使用Session.createQuery()方法来得到一个Query。
使用Query.list方法向数据库查询数据,hibernate会自动把数据封装为相应的List集合。你也可以使用query.iterate()来得到一个Iterate。
查询单个对象(使用 uniqueResult()):
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String hql = "from Student where id = 1";
Query query = session.createQuery(hql);
Student student = (Student)query.uniqueResult();
System.out.println(student);
session.getTransaction().commit();
}
HQL 语句里可以有where字句,其中where id = 1 查找 id属性为1的学生,注意的是id是Student对象的属性,而不是表的列名!
确得查询结果只有一条记录事,可以使用Query.uniqueResult()方法。hibernate会自动把数据封闭为相应的对象。
查询指定的列:
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String hql = "select id,name from Student";
Query query = session.createQuery(hql);
List<Object[]> s = query.list();
session.getTransaction().commit();
}
HQL可以只查询表的其中一列或多列。使用select字句,其中id和name是Student对象的属性名,而不是表的列名!
只查询指定列返回的是一个List<Object[]>对象。List里的一条记录对应数据库表的一行。Object[]的一个元素即对应表的一个单元格。
如果使用 uniqueResult() 那返回的就是Object[]对象。
带命名参数的HQL:
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String hql = " from Student where name like :name";
Query query = session.createQuery(hql);
query.setString("name", "张%");
List<Student> s = query.list();
session.getTransaction().commit();
}
在HQL中,使用 : 加命名(如 :name)作为占位符,再使用Query.setString(),query.setInteger()等方法为相应的占位符设置参数(不确定类型可以使用setParameter())。
上面例子中的HQL语句等同于 "from Student where name like '张%'"
实例参数查询:
通过添加一个新类来作为HQL语句查询条件的参数。
public class BookQuery {
private String name;
private String author;
private double maxPrice;
private double minPrice;
//省略get,set语句.........
}
查询任意名字,作者姓张,价格在5-20之间的图书:
public static void main(String[] args) {
//创建查询条件对象
BookQuery bq= new BookQuery();
bq.setName("%");
bq.setAuthor("张%");
bq.setMinPrice(5);
bq.setMaxPrice(20);
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String hql = "from Book where name like :name "
+ "and author like :author "
+ "and price between :minPrice and :maxPrice";
Query query = session.createQuery(hql);
//把查询条件对象作为HQL查询的参数
query.setProperties(bq);
List<Book> books = query.list();
session.getTransaction().commit();
}
BookQuery类的属性名必须和HQL语句的参数名一致,并提供get,set方法。
通过 setProperties()方法把查询条件对象作为HQL查询的参数。
连接查询(join 语法):
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String hql = "from Student s inner join s.grade g";
Query query = session.createQuery(hql);
List<Object[]> s = query.list();
session.getTransaction().commit();
}
内连接使用join,左外连接使用left join,右外连接使用reght join。和sql语句基本一致。
join 后面是 s.grade 而不是直接写 Grade 类名。
因为表之间的关联关系已经通过映射文件或注解设好,所以在join子句中不需要声明关系。
上面例子里同时返回学生和班级的所有信息,返回值是一个 List<Object[]><Object[]> 。其中每一个Object[]里,下标0的元素为Student对象,下标1的元素为Grade对象。
使用聚合函数:
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String hql = "Select count(s) from Student s";
Query query = session.createQuery(hql);
Object count = query.uniqueResult();
session.getTransaction().commit();
}
count()求总数、avg(...), sum(...), min(...), max(...)分别是平均值,总和,最大,最小值。
Hibernate 分页:
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
String hql = "from Student ";
Query query = session.createQuery(hql);
query.setFirstResult(2);
query.setMaxResults(2);
List<Student> s = query.list();
System.out.println(s);
session.getTransaction().commit();
}
setFirstResult:设置开始行,从0开始。
setMaxResults:设置取的记录数。
HQL命名查询:
通过把hql语句写到外部映射文件(*.hbm.xml)来实现HQL和代码分离。
在学生表的映射文件中加入如下代码:
<query name="getStudent">
<![CDATA[from Student where id=:id]]>
</query>
<query>标签写在<hibernate-mapping>标签内。
<![CDATA[ ]]> 写的是一条HQL语句。
通过<query>标签的name属性为该HQL指定一个名称。
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
Query query = session.getNamedQuery("getStudent");
query.setInteger("id", 6);
Student s = (Student)query.uniqueResult();
session.getTransaction().commit();
}
通过session.getNamedQuery()方法得到一个用于命名查询的Query。把HQL语句的名称传进去。
Hibernate 查询:HQL查询(Hibernate Query Languge)的更多相关文章
- hibernate的hql查询
1.概念介绍 1.Query是Hibernate的查询接口,用于从数据存储源查询对象及控制执行查询的过程,Query包装了一个HQL查询语句. 2.HQL是Hibernate Query Langua ...
- Hibernate之HQL查询
一.Hibernate 提供了以下几种检索对象的方式: 导航对象图检索方式: 根据已经加载的对象导航到其他对象 OID 检索方式: 按照对象的 OID 来检索对象 HQL 检索方式:使用面向对象的 H ...
- Hibernate五 HQL查询
HQL查询一 介绍1.HQL:Hibernate Query Language,是一种完全面向对象的查询语言.使用Hibernate有多重查询方式可供选择:hibernate的HQL查询,也可以使用条 ...
- Hibernate的查询 HQL查询 查询某几列
HQL 是Hibernate Query Language的简写,即 hibernate 查询语言:HQL采用面向对象的查询方式.HQL查询提供了更加丰富的和灵活的查询特性,因此Hibernate将H ...
- Hibernate 的hql查询简介【申明:来源于网络】
Hibernate 的hql查询简介[申明:来源于网络] Hibernate 的hql查询简介:http://blog.csdn.net/leaf_130/article/details/539329 ...
- HQL查询——HQL查询的基本用法
HQL查询--HQL查询的基本用法 1.HQL语法类似于SQL语法,但是需要注意的是,HQL是一种完全面向对象的查询语言.SQL语言操作的对象是数据表.列等数据库对象,而HQL语言的操作对象是类.实例 ...
- Hibernate之HQL查询的一些例子
Hibernate配备了一种非常强大的查询语言,就是HQL(hibernate query language),HQL看上去很像sql,但只是语法结构上相似,HQL是一种面向对象的查询,他可以理解继承 ...
- Hibernate(十)HQL查询二
一.数据库的emp名和dept表 建立持久化类和配置文件,可以用MyEclipse直接生成 持久化类 package entity; import java.util.Date; public cla ...
- Hibernate(九)HQL查询
一.Hibernate提供的查询方式 OID查询方式:主键查询.通过get()或者load()方法加载指定OID的对象查询结果为一个 HQL查询方式:通过Query接口使用HQL语言进行查询 QBC查 ...
- hibernate 中HQL查询
由于比较简单,在此处只写一些HQL语言. 表关系,多对一. CREATE TABLE `user` ( `id` ) NOT NULL AUTO_INCREMENT, `uname` varchar( ...
随机推荐
- elasticsearch,http://ip:9200访问不到的解决办法
现在解压elasticsearch之后,启动,通过http://localhost:9200可以访问的到,但是http://ip:9200访问不到,怎么办呢?带你解决,带你飞 修改elasticsea ...
- .Net Memory -- GC基本知识
参考资料: http://blogs.msdn.com/b/tess/archive/2008/04/17/how-does-the-gc-work-and-what-are-the-sizes-of ...
- OER 7451 in Load Indicator : Error Code = OSD-04500:指定了非法选项
alert 日志错误OER 7451 in Load Indicator : Error Code = OSD-04500:指定了非法选项 Sun Apr 22 11:15:51 2012 OER 7 ...
- setInterval()-----------js 函数总结
setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式. setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭.由 s ...
- php word转HTML
因为安装的的xampp不知道如何查看我的Apache版本是多少,就先把com.allow_dcom=true打开了,但是仍旧报错说找不到com类,然后就把下面的extension扩展添加到php.in ...
- 添加事件监听兼容IE6-8
IE8一下浏览器不支持addEventListener,用attachEvent取而代之,但是在时间类型前面要加上’on‘,例如click时间在attachEvent中要写成onclick. var ...
- HTML常用字符
显示结果 描述 实体名称 实体编号 空格 < 小于号 < < > 大于号 > > & 和号 & & " 引号 &quo ...
- SQL数据转移
方法一:如果想把数据库A中的表Table1中的数据复制到数据库B中的表Table2中,也就是要预先建立Table2,可以使用一下语句: use B goinsert into Table2 selec ...
- ubuntu centos debina
文章目录CentOSDebianCentOS与Debian哪个好?Ubuntu买VPS时有CentOS.Debian.Ubuntu三种操作系统可以选择,Linux下哪种系统更好是很多新人都会遇到的问题 ...
- zedboard--Opencv的移植(十)
今天终于把Opencv的移植搞定了,花了一天的时间,主要是参考了书上和rainysky的博客.下载的2.3.1的版本 第一步肯定是下载opencv的源码包了,在opencv的官网上下载http://s ...