HQL(Hibernate Query language)语言
现在有两张表:student(学生表),classroom(教室表).
//对象 Student 对应 student 表中有四个字段,分别是:id,name,age,classroom;
public class Student
{
private int id;
private String name;
private int age;
private Classroom classroom;
} //对象Classroom 对应 classroom 表中有两个字段:id,name,students;
public class Classroom
{
private int id;
private String name;
private Set<Student> students;
}
Student 是一个对象,student 是数据库中的一个表.
查询所有的Student对象时,最简单的HQL语句是: from Student,也可以写成 select s from Student (as) s. 注:这的as可以省略
1.简单的查询遍历对象:
// 遍历Student
Query query = session.createQuery("form Student");
// 注: 如果Student对象不是唯一的,那么需要写上包名,如: from test.Student test为包名.
List list = query.list();
for (int i = 0; i < list.size(); i++) {
Student stu = (Student) list.get(i);
System.out.println(stu.getName());
}
// 注意:
// 如果执行HQL语句"from Student,Course",并不时单单返回两个对象,而是返回两个对象的笛卡尔积,这类似SQL语句中字段的全外连接.实际的应用中,"from Student,Course"这种语句几乎是不回出现的.
2.属性查询:
// ----单个属性查询:
Query query = session.createQuery("select s.name form Student s");
List list = query.list();
for (int i = 0; i < list.size(); i++) {
String name = (String) list.get(i);
System.out.println(name);
} // ----多个属性查询:
Query query = session.createQuery("select s.name,s.age form Student s");
List list = query.list();
for (int i = 0; i < list.size(); i++) {
Object obj[] = (Object[]) list.get(i); // 取得list中的第i个对象
System.out.println(obj[0] + "的年龄为: " + obj[1]);
}
3.实例化查询:
// 实例化查询结果可以说是对属性查询的一重改进.在使用属性查询时由于使用对象数组,操作和理解不太方便,
// 如果将以个Object[]中的成员封装成一个对象就方便多了.
Query query = session.createQuery("select new Student(s.name,s.age) form Student s");
List list = query.list();
for (int i = 0; i < list.size(); i++) {
Student stu = (Student) list.get(i);
System.out.println(stu.getName());
} // 注:运行这个程序的时候,需要一个new Student(s.name,s.age)构造函数.在Student.java中编写这个构造函数.
public Student(String name, int age) {
this.name = name;
this.age = age;
}
4.动态参数查询:
1)、基于 ? 的参数形式
/*
* setParameter的方式可以防止sql注入 jdbc的setParameter的下标从1开始,hql的下标从0开始
*/
Query query = session.createQuery("select stu from Student stu where name like ? ");
query.setParameter(0, "%张三%");
List list = query.list();
for (int i = 0; i < list.size(); i++) {
Student stu = (Student) list.get(i);
System.out.println(stu.getName());
}
2)、基于 :xx 的别名参数形式
/*
* 通过 :xxx 格式设置别名
*/
Query query = session.createQuery("select stu from Student stu where name like :name ");
query.setParameter("name","%李四%");
List list = query.list();
for (int i = 0; i < list.size(); i++) {
Student stu = (Student) list.get(i);
System.out.println(stu.getName());
}
注意:如果返回结果只有一个,可以在 Query 后使用 uniqueResult 方法 e.g.: query.uniqueResult();
in 查询: "from Student where id in (:ids)" 传入参数使用 query.setParameterList("ids", new Integer[] { 1, 2 });
5.分页查询:
在 Query 后 使用 setFirstResult(x) 方法设置从第x条开始取,使用 setMaxResults(y) 方法设置取出y条数据 query.setFirstResult(0).setMaxResults(10);
6.连表查询:
1: inner jion (内连接); inner jion 可以简写为join
2: left outer join (左外连接)
3: right outer join(右外连接)
4: full join(全连接--不常用)
/*
* inner join
* sql 与 hql 区别:
* sql: select s.* from Student s join Classroom c on s.cid=c.id
* hql: select s from Student s join s.classroom room
*/
Query query = session.createQuery("select s from Student s join s.classroom room where room.id=2");
List list = query.list();
for (int i = 0; i < list.size(); i++) {
Student stu = (Student) list.get(i);
System.out.println(stu.getName());
}
7.聚合函数查询:
//1: count() 统计记录的条数
//2: min() 求最小值
//3: max() 求最大值
//4: sum() 求和
//5: avg() 求平均值
// 取得Student的数量
Query query = session.createQuery("select count(*) from Student"); // avg()取得Student平均年龄
query = session.createQuery("select avg(s.age) from Student as s"); // upper()方法将字符串转为大写
query = session.createQuery("select upper(s.name) from Student as s"); // 去除重复行distinct
query = session.createQuery("select distinct s.age from Student as s");
8.子查询:
//all 表示所有记录
//any 便是所有记录中的任意一条
//somy 与any用法一样
//in 等价于any
//exists 表示子查询至少要返回一条数据. //all:
from Team t where 22 < all(select s.age from Student s) from Team t where all(select s.age from t.student s) > 22
9.修改update()
Student stu=(Student)session.get(Student.class,"id"); //根据id 得到stu对象
stu.setName("123");
session.update(stu);
10.删除:delete()
Student stu=(Student)session.get(Student.class,"id"); //根据id 得到stu对象
session.delete(stu);
HQL(Hibernate Query language)语言的更多相关文章
- hql(Hibernate Query Language)
1.Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Language)查询提供了更加丰富的和灵活的查询特性,因此Hibernate ...
- Hibernate查询(HQL——Hibernate Query Language)
HQL查询 HQL提供了是十分强大的功能,它是针对持久化对象,用取得对象,而不进行update,delete和insert等操作.而且HQL是面向对象的,具备继承,多态和关联等特性. from子句: ...
- 常用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() ...
- Hibernate Query Language查询:
Hibernate Query Language查询: Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Language)查询提供 ...
- 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(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基础Query简单查询结果for输出和Iterator输出
HQL第一次课: hibernate Query Language:hibernate 查询语言 语法: query: String hql="from dept"; Query ...
- 类型:。net;问题:HQL;结果:HQL: Hibernate查询语言
HQL: Hibernate查询语言 Hibernate配备了一种非常强大的查询语言,这种语言看上去很像SQL.但是不要被语法结构 上的相似所迷惑,HQL是非常有意识的被设计为完全面向对象的查询,它可 ...
随机推荐
- 我和小美的撸码日记--基于MVC+Jqgrid的.Net快速开发框架
前言:以前的帐号没有发首页的权限,特此把这篇文章从另外一个博客移过来,这篇是<我和小美的撸码日记>的序 一转眼务农6年了,呆过大公司也去过小作坊,码农的人生除了抠腚还是抠腚.在所有呆过的公 ...
- EXTJS 4.2 实现 gridpanel 鼠标悬停单元格以提示信息的方式显示单元格内容。
由于gridpanel的单元格里的文字太多时候,都由省略号代替,就想实现如题的功能,经过反复实验,终于搞定了!直接上代码: me.on('itemmouseenter', function (view ...
- hdu 4585 Shaolin_set用法
题目链接 题意:有n个人想成为少林,但是成为少林必须跟少林的大师大一场,当然要选择战斗力很近的,有两大师战斗力跟那人相近程度一样就选战斗力小的那个,按输入顺序,先输入的人先成为少林大师,后面输入的人, ...
- 盒子模型&position定位
有时候深深的感觉语文这门课程其实很有用, 至少以前学的时候没有感觉到 直到现在阅读大量的别人的资料文章的时候或者是看一些题目....... 总之:认真阅读小心品味 当然,前面的孤言自语和本文无关,只是 ...
- jQuery Pagination Ajax分页插件中文详解(摘)
jQuery Pagination Ajax分页插件中文详解 by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxin ...
- UVA 536 (13.08.17)
Tree Recovery Little Valentine liked playing with binary trees very much. Her favoritegame was con ...
- 微软提供了三个核心服务:Windows+Office 365+Azure
微软提供了三个核心服务:Windows+Office 365+Azure 英语新闻来源:http://techcrunch.com/2014/11/10/microsofts-ceo-breaks-d ...
- LR选择哪种方式录制
LR选择哪种方式录制,有以下考虑原则: 1.基于浏览器的应用程序推荐使用HTML-basic script方式录制 2.不是基于浏览器的应用程序推荐使用URL-basic script方式录制 3.如 ...
- javascript 之 this 用法
参考视频:http://www.imooc.com/video/6430 JavaScript中的this比较灵活,也是让很多初学者摸不到头脑,那么根据在不同的环境下,在同一个函数,不同的调用方式下, ...
- css之浏览器初始化方案
HTML, body, div, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, dt, dd, p, blockquote,pre, form, fieldset, ...