常用HQL(Hibernate Query Language)查询
查询一个对象(实体类必须有一个不带参数的构造方法)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
@Test public void test01() { Session session = null ; try { session = HibernateUtil.openSession(); /** * 对于HQL而言,都是基于对象进行查询的 */ Query query = session.createQuery( "from Special" ); List<Special> spes = query.list(); for (Special spe:spes) { System.out.println(spe.getName()); } } catch (Exception e) { e.printStackTrace(); } finally { HibernateUtil.close(session); } } |
使用select查询
1
2
3
4
5
6
7
8
9
|
//不能使用select *进行查询 //Query query = session.createQuery("select * from Special"); /** * 可以使用链式查询的方式 */ List<Special> spes = session.createQuery( "select spe from Special spe" ).list(); for (Special spe:spes) { System.out.println(spe.getName()); } |
条件查询
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
List<Student> stus = session .createQuery( "from Student where name like '%张%'" ) .list(); for (Student stu:stus) { System.out.println(stu.getName()); } ------------------------------------------------- /** * 基于?的条件的查询 * 特别注意:jdbc设置参数的最小下标是1,hibernate是0 */ List<Student> stus = session .createQuery( "from Student where name like ?" ) .setParameter( 0 , "%李%" ) .list(); for (Student stu:stus) { System.out.println(stu.getName()); } ------------------------------------------------ /** * 还可以基于别名进行查询,使用:xxx来说明别名的名称 */ List<Student> stus = session .createQuery( "from Student where name like :name and sex=:sex" ) .setParameter( "name" , "%刘%" ) .setParameter( "sex" , "男" ) .list(); for (Student stu:stus) { System.out.println(stu.getName()); } |
使用uniqueResult可以返回唯一的一个值/对象
1
2
3
4
5
6
7
8
9
10
11
12
13
|
Long stus = (Long)session .createQuery( "select count(*) from Student " + "where name like :name and sex=:sex" ) .setParameter( "name" , "%刘%" ) .setParameter( "sex" , "男" ) .uniqueResult(); System.out.println(stus); ------------------------------------------------------ Student stu = (Student)session .createQuery( "select stu from Student stu where id=:id" ) .setParameter( "id" , 1 ) .uniqueResult(); System.out.println(stu.getName()); |
基于投影的查询,通过在列表中存储一个对象的数组
1
2
3
4
5
6
7
|
List<Object[]> stus = session .createQuery( "select stu.sex,count(*) from Student stu " + "group by stu.sex" ) .list(); for (Object[] obj:stus) { System.out.println(obj[ 0 ]+ ":" +obj[ 1 ]); } |
如果对象中相应的导航对象,可以直接导航完成查询
1
2
3
4
5
6
7
8
|
List<Student> stus = session .createQuery( "select stu from Student stu " + "where stu.classroom.name=? and stu.name like ?" ) .setParameter( 0 , "计算机教育班" ).setParameter( 1 , "%张%" ) .list(); for (Student stu:stus) { System.out.println(stu.getName()); } |
可以使用in来设置基于列表的查询,此处的查询需要使用别名进行查询
特别注意,使用in的查询必须在其他的查询之后
1
2
3
4
5
6
7
8
9
|
List<Student> stus = session .createQuery( "select stu from Student stu " + "where stu.name like ? and stu.classroom.id in (:clas)" ) .setParameter( 0 , "%张%" ) .setParameterList( "clas" , new Integer[]{ 1 , 2 }) .list(); for (Student stu:stus) { System.out.println(stu.getName()); } |
使用setFirstResult和setMaxResult可以完成分页的offset和pageSize的设置
1
2
3
4
5
6
7
8
9
|
List<Student> stus = session .createQuery( "select stu from Student stu " + "where stu.classroom.id in (:clas)" ) .setParameterList( "clas" , new Integer[]{ 1 , 2 }) .setFirstResult( 0 ).setMaxResults( 15 ) .list(); for (Student stu:stus) { System.out.println(stu.getName()); } |
可以通过is null来查询为空的对象,和sql一样不能使用=来查询null的对象
1
2
3
4
5
6
7
8
|
List<Student> stus = session .createQuery( "select stu from Student stu " + "where stu.classroom is null" ) .setFirstResult( 0 ).setMaxResults( 15 ) .list(); for (Student stu:stus) { System.out.println(stu.getName()); } |
连接查询
1
2
3
4
5
6
7
8
9
10
11
12
13
|
/** * 使用对象的导航可以完成连接,但是是基于Cross JOIN,效率不高, * 可以直接使用JOIN来完成连接 */ List<Student> stus = session .createQuery( "select stu from Student stu " + "left join " + "stu.classroom cla where cla.id=2" ) .setFirstResult( 0 ).setMaxResults( 15 ) .list(); for (Student stu:stus) { System.out.println(stu.getName()); } |
统计班级学生的人数
1
2
3
4
5
6
7
|
List<Object[]> stus = session .createQuery( "select cla.name,count(stu.classroom.id) from Student stu " + "right join stu.classroom cla group by cla.id" ) .list(); for (Object[] stu:stus) { System.out.println(stu[ 0 ]+ "," +stu[ 1 ]); } |
把查询出来的数据封装成一个对象。
定义一个学生对象DTO
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
package org.zttc.itat.model; /** * DTO对象没有存储的意义,仅仅是用来进行数据的传输的 * */ public class StudentDto { private int sid; private String sname; private String sex; private String cname; private String spename; //省去set get方法 public StudentDto( int sid, String sname, String sex, String cname,String spename) { super (); this .sid = sid; this .sname = sname; this .sex = sex; this .cname = cname; this .spename = spename; } public StudentDto() { } } |
查询
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
/** * 直接可以使用new XXObject完成查询, * 注意,一定要加上Object的完整包名 * 这里使用的new XX,必须在对象中加入相应的构造函数 */ List<StudentDto> stus = session .createQuery( "select new org.zttc.itat.model.StudentDto" + "(stu.id as sid,stu.name as sname,stu.sex as sex," + "cla.name as cname,spe.name as spename) " + "from Student stu left join stu.classroom cla " + "left join cla.special spe" ) .list(); for (StudentDto stu:stus) { System.out.println(stu.getSid()+ "," +stu.getSname()+ "," + stu.getSex()+ "," +stu.getCname()+ "," +stu.getSpename()); } |
having是为group来设置条件的
1
2
3
4
5
6
7
8
|
List<Object[]> stus = session.createQuery( "select spe.name," + "(count(stu.classroom.special.id)) from Student stu right join " + "stu.classroom.special spe group by spe " + "having count(stu.classroom.special.id)>150" ) .list(); for (Object[] obj:stus) { System.out.println(obj[ 0 ]+ ":" +obj[ 1 ]); } |
常用HQL(Hibernate Query Language)查询的更多相关文章
- hql(Hibernate Query Language)
1.Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Language)查询提供了更加丰富的和灵活的查询特性,因此Hibernate ...
- Hibernate Query Language查询:
Hibernate Query Language查询: Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Language)查询提供 ...
- Hibernate查询(HQL——Hibernate Query Language)
HQL查询 HQL提供了是十分强大的功能,它是针对持久化对象,用取得对象,而不进行update,delete和insert等操作.而且HQL是面向对象的,具备继承,多态和关联等特性. from子句: ...
- HQL: The Hibernate Query Language
Chapter 14. HQL: The Hibernate Query Language 14.1. Case Sensitivity 14.2. The from clause 14.3. Ass ...
- HQL基础Query简单查询结果for输出和Iterator输出
HQL第一次课: hibernate Query Language:hibernate 查询语言 语法: query: String hql="from dept"; Query ...
- HQL(Hibernate Query Language)
1. NativeSQL > HQL > EJB QL(JP QL 1.0) > QBC(Query By Criteria) > QBE(Query By Example)2 ...
- Hibernate hql(hibernate query language)基础查询
在开发过程中,数据库的操作我们其实更多的用到的是查询功能,今天开始学习hql的查询. 1.加入必要的工具 2.Hibernate配备的一种非常强大的查询语言,这种查询语言看上去很像sql.但是不要被语 ...
- HQL(Hibernate Query language)语言
现在有两张表:student(学生表),classroom(教室表). //对象 Student 对应 student 表中有四个字段,分别是:id,name,age,classroom; publi ...
- Hibernate的批量查询——HQL
HQL(Hibernate Query Language)查询: 1.查询所有学生信息: public static void testSel() { Session session = Hibern ...
随机推荐
- Linux中断 - ARM中断处理过程
一.前言 本文主要以ARM体系结构下的中断处理为例,讲述整个中断处理过程中的硬件行为和软件动作.具体整个处理过程分成三个步骤来描述: 1.第二章描述了中断处理的准备过程 2.第三章描述了当发生中的时候 ...
- linux系统调用sysconf
1.前言 当前计算机都是多核的,linux2.6提供了进程绑定cpu功能,将进程指定到某个core上执行,方便管理进程.linux提供了sysconf系统调用可以获取系统的cpu个数和可用的cpu个数 ...
- Python 字典 in 操作符
描述 Python 字典 in 操作符用于判断键(key)是否存在于字典(D)中,如果键在字典中返回True,否则返回False. 在Python2中还可以使用 has_key() 方法,官方文档推荐 ...
- Python istitle() 方法
描述 istitle() 方法检测字符串中所有的单词拼写首字母是否为大写,且其他字母为小写. 语法 istitle() 方法语法: S.istitle() 参数 无. 返回值 如果字符串中所有的单词拼 ...
- Spring注解运行时抛出null
关于Spring的注解其实不难,大致需要以下几个流程: 一.配置Spring的注解支持 <?xml version="1.0" encoding="UTF-8&qu ...
- 关于apache服务器加载so的报错
早上突然发现我的虚拟机上的WEB应用访问不了了,后台检查httpd服务,无法启动,出现一行提示: ①starting httpd: httpd: Syntax error on line 163 of ...
- Android开发14——监听内容提供者ContentProvider的数据变化
一.提出需求 有A,B,C三个应用,B中的数据需要被共享,所以B中定义了内容提供者ContentProvider:A应用修改了B应用的数据,插入了一条数据.有这样一个需求,此时C应用需要得到数据被修改 ...
- Qt中使用DOM解析XML文件或者字符串(实例)
因为需要读取配置文件,我的配置文件采用xml:因此编写了使用qt读取xml文件内容的代码,xml文件如下: <?xml version="1.0" encoding=&quo ...
- Artificial-Intelligence BOOKs与算法
http://mindhacks.cn/2008/09/11/machine-learning-and-ai-resources/ https://www.amazon.com/Information ...
- 黑客编程教程(八)编写NT服务
先介绍一下什么是NT服务,实际上就是一个可以在系统启动时自动在一定身份下启动的,伴随着系统长期存在的进程. 一个NT服务有三部分构成: :Service Control Manager(SCM) 每个 ...