1.HQL:(Hibernate Query Language) 是面向对象的查询语言

1.实体查询

  1. public void testQueryAllDept(){
  2. String hql="from Employee";
  3. //hql="from com.sh.Entity";
  4. Query query=session.createQuery(hql);
  5. List<Employee> list= query.list();
  6. //...
  7. }

2.有条件的 实体查询

  1. public void testQueryAllDept(){
  2. String hql="from Deptas model where mode.deptName='人事部' ";
  3. //hql="from com.sh.Entity";
  4. Query query=session.createQuery(hql);
  5. List<Employee> list= query.list();
  6. //...
  7. }
  8. public void testQueryAllDept(){
  9. String hql="from Deptas model where mode.deptName like '%部%' ";
  10. //hql="from com.sh.Entity";
  11. Query query=session.createQuery(hql);
  12. List<Employee> list= query.list();
  13. //...
  14. }
  15. public void testQueryDeptByGt(){
  16. String hql="from Dept model where model.createDate> '2012-03-10'";
  17. Query query=session.createQuery(hql);
  18. List<Employee> list= query.list();
  19. }

3.HQL 中的各种运算符

运算符类型 HQL运算符 含义
比较运算 = 等于
  <> 不等于
  > 大于
  >= 大于等于
  <= 小于等于
  < 小于
  is null 为空
  is not null 不为空
范围运算 in 等于列表中的某一值
  not in 不等于列表中的任意一个值
  between  p1 and p2 大于等于值1  且 小于等于值2
  not between p1 and p2 小于值1 或者 大于 值2
字符串模式匹配 like 字符串模式匹配
逻辑运算 and
  or
  not

3.更新 删除

  1. public void testModifyDate(){
  2. Transaction tr=session.beginTransaction();
  3. Dept detp=(Dept)session.get(Detp.class,new Integer(6));
  4. detp.seteCreateDate("2000-03-10");
  5. tr.commit();
  6. }
  7. // delete  删除
  8. public void testDelDeptByHql(){
  9. Transaction tr=session.beginTransaction();
  10. String hql="delete Dept as model where model.deptId=6";
  11. Query query=session.createQuery(hql);
  12. query.executeUpdate();
  13. tr.commit();
  14. }

4.属性查询

  1. public void testQueryDeptName(){
  2. String hql="select model.deptName from Dept as model";
  3. Query query=session.createQuery(hql);
  4. List<String> deptNameList=query.list();
  5. //...
  6. }
  7. public void testQueryDeptName(){
  8. String hql="select model.deptName,model.createDate from Dept as model";
  9. Query query=session.createQuery(hql);
  10. List<Object[]> prsList=query.list();
  11. for(){
  12. }
  13. //...
  14. }
  15. //采用对象进行 保存 查询的字段(要添加 对应字段的构造方法)
  16. public void testQueryDeptName(){
  17. String hql="select new Dapt(model.deptName,model.createDate) from Dept as model";
  18. Query query=session.createQuery(hql);
  19. List<Dept> deptList=query.list();
  20. for(Dept d:deptList){
  21. d.setDeptName("test");
  22. session.saveOrUpdate(dept);
  23. }
  24. //...
  25. }
  26. //如果采用对象 保存上面查询出来的对象  如果对其进行更新的操作 是不会成功的
  27. public void testSaveDept(){
  28. Transction  tr=session.beginTransactino();
  29. String hql="select new Dept(model.deptName,model.createDate) from Dept as model";
  30. Query query=session.createQuery();
  31. List<Dept> deptList=query.list();
  32. for(Dept dept:deptList){
  33. System.out.println(dept.deptName);
  34. dept.setDetpName("test");
  35. session.saveOrUpdate(dept);
  36. }
  37. tr.commit();
  38. // 最后 根本就没有更新 而是 在数据库中 插入 新的记录
  39. }

5.使用函数

  1. public void testQuyeryFunction(){
  2. String hql="select count(*),min(model.createDate) from Dept as model";
  3. Query query=session.createQuery(hql);
  4. List<Object[]> paramsList=query.list();
  5. for(){
  6. }
  7. //...
  8. }

6.分组 与 排序

  1. //排序
  2. public void testQueryOrderBy(){
  3. String hql="from Dept as mode order by   model.createDate,model.deptName desc";
  4. Query query=session.createQuery();
  5. List<Dept> deptList=query.list();
  6. for(){}
  7. //
  8. }
  9. //分组 并且 使用  having 筛选
  10. public void testQueryGroupBy(){
  11. String hql="select count(model),model.deptName from Dept as model group by model.deptName having count(model)>1";
  12. Query query=session.createQuery();
  13. List<Object[]> list=query.list();
  14. //...
  15. }

7.查询单个对象

  1. public void testQueryUn(){
  2. String hql="select model.deptName from Dept as model where model.deptId=2";
  3. Query query=session.createQuery(hql);
  4. query.setMaxResults(1);
  5. String deptName=(String)query.uniqueResult();
  6. System.out.println(deptNamae);
  7. }

8.绑定参数 
释义:Hibernate中也采用了preparedStatement作为底层数据库的的访问方式,与之对应的SQL语句 可以重用preparedStatement对象, 首先会预编译,然后缓存起来,提高性能.

1.使用 ":"加参数名 绑定参数

  1. public void  testQueryByParamsName(){
  2. //使用  ":参数名" 来传递参数
  3. String hql="from Dept as model where
  4. odel.deptName=:deptName and model.createDate=:createDate";
  5. Query query=session.createQuery(hql);
  6. query.setString("deptName","test");
  7. query.setString("ceateDate","2000-02-10");
  8. List<Dept> deptList=query.list();
  9. for(){}
  10. //...
  11. }

2.使用 "?" 按照位置来绑定参数

  1. public void testQueryByParamsID(){
  2. String hql="from Dept as model where model.deptName=? and model.createDate=?";
  3. Query query=session.createQuery(hql);
  4. query.setString(0,"test");
  5. query.setString(1,"2000-02-02");
  6. List<Dept> list=query.list();
  7. for(){}
  8. //..
  9. }

3.采用setEntity() 将参数和一个持久化对象进行绑定

  1. public void testQueryByDept(){
  2. Dept dept=(Dept)Session.get(Dept.clas,new Integer(2));
  3. String hql="select Employee  as model where model.dept=?"
  4. Query query=session.createQuery(hql);
  5. query.setEntity(0,dept);
  6. List<Employee> empList=query.list();
  7. for(){}
  8. //..
  9. }

4.setParameter() 用于绑定任意类型的参数

  1. public void testQueryBySetParams(){
  2. String hql="from Dept as model where model.deptName=?";
  3. Query query=session.createQuery(hql);
  4. query.setParameter(0,"test");
  5. List<Dept> deptList=query.list();
  6. for(){}
  7. //..
  8. }

5.setProperties() 将一个参数名 于一个对象的属性值绑定

  1. public void testQueryBySetPro(){
  2. Dept deptNew=new  Dept();
  3. deptNew.setDeptName("test");
  4. String hql="from Dept as model where model.deptName=:deptName";
  5. Query query=session.createQuery();
  6. query.setProperties(deptNew);
  7. List<Dept> deptList=query.list();
  8. for(){
  9. }
  10. //..
  11. }

10. 联合查询 
inner join

  1. public void testQueryInnerJoin(){
  2. String hql="from Dept as model inner join model1.employees as model2";
  3. Query query=session.createQuery(hql);
  4. List<Object[]> objList=query.list();
  5. for(Object[] obj:objList){
  6. Dept dept=(Dept)obj[0];
  7. Employee emp=(Employee)obj[1];
  8. System.out.println("xxxx");
  9. }
  10. }

left join

  1. public void testQueryLeftJoin(){
  2. String hql="from Dept as model left join model1.employees as model2";
  3. Query query=session.createQuery(hql);
  4. List<Object[]> objList=query.list();
  5. for(Object[] obj:objList){
  6. Dept dept=(Dept)obj[0];
  7. Employee emp=(Employee)obj[1]; //有可能为空 所以需要判断
  8. if(mep!=null){
  9. System.out.println("xxxx");
  10. }else{
  11. System.out.println(null);
  12. }
  13. System.out.println(dept.getDeptName());
  14. }
  15. }

right join

  1. public void testQueryRightJoin(){
  2. String hql="from Dept as model right join model1.employees as model2";
  3. Query query=session.createQuery(hql);
  4. List<Object[]> objList=query.list();
  5. for(Object[] obj:objList){
  6. Dept dept=(Dept)obj[0];
  7. Employee emp=(Employee)obj[1]; //有可能为空 所以需要判断
  8. if(dept!=null){
  9. System.out.println(dept.getDeptName());
  10. }else{
  11. System.out.println(null);
  12. }
  13. System.out.println("dd"+emp.getEmployeeName());
  14. }
  15. }

11.子查询

  1. public void testQueryChild(){
  2. String hql="from Dept as model where (select count(*) from model.employee) >2";
  3. Query query=session.createQuery(hql);
  4. List<Dept> objList=query.list();
  5. for(){}
  6. //..
  7. }

12 Criteria 查询 
释义:通过面向对象的设计将数据查询条件封装在一个对象

  1. //无条件
  2. public void testQueryDept(){
  3. Criteria criteria=session.createCriteria(Dept.class);
  4. List<Dept> deptList=criteria.list();
  5. for(){}
  6. //..
  7. }
  8. //添加条件
  9. public void testQueryDeptByName(){
  10. Criteria criteria=session.createCriteria(Dept.class);
  11. criteria.add(Expression.eq("deptName", "人事部"));
  12. List<Dept> deptList=criteria.list();
  13. for(){}
  14. //..
  15. }

SQL语法查询机制

方法 描述
Expression.eq 对应sql中的field =value
Expression.gt 对应sql中的field>value
Expression.ge 对应sql中的field>=value
Expression.lt 对应sql中的field<value
Expression.le 对应sql中的field<=value
Expression.between 对应sql中的between
Expression.like 对应 like
Expression.in 对应 in
Expression.eqProperty 用于比较两个属性之间的值,对应的Sql条件中field=field
Expression.gtProperty 用于比较两个属性之间的值,对Sqlfiled>field
Expression.geProperty 用于比较两个属性之间的值,对应sql field>=field
Expression.ltProperty 用于比较两个属性之间的值,对应field<field
Expression.leProperty 用于比较 两个属性之间的值,对应field<=field

Hibernate3中采用Restrictions类代替Expression

  1. public void  testQueryDeptByNameRe(){
  2. Criteria  criteria=session.createCriteria(Dept.class);
  3. criteria.add(Restrictions.eq("deptName", "人事部"));
  4. List<Dept> deptList=criteria.list();
  5. for(){}
  6. //..
  7. }

Criteria中限定返回的行数

  1. public void testQueryDept(){
  2. Criteria criteria=session.createCriteria(Dept.class);
  3. criteria.setFirstResult(2);
  4. criteria.setMaxResults(2);
  5. List<Dept> deptList=criteria.list();
  6. for(){}
  7. //..
  8. }

Criteria排序

    1. public void testQueryDept(){
    2. Criteria criteria=session.createCriteria(Dept.class);
    3. criteria.addOrder(Order.asc("createDate"));
    4. List<Dept> deptList=criteria.list();
    5. for(){}
    6. //..
    7. }

Hibernate 的HQL,QBC 查询语言的更多相关文章

  1. Hibernate之HQL查询

    一.Hibernate 提供了以下几种检索对象的方式: 导航对象图检索方式: 根据已经加载的对象导航到其他对象 OID 检索方式: 按照对象的 OID 来检索对象 HQL 检索方式:使用面向对象的 H ...

  2. Hibernate之HQL介绍

    Hibernate中提供了多种检索对象的方式,主要包括以下种类: 导航对象图检索方式:根据已经加载的对象导航到其他对象 OID检索方式:根据对象的OID来检索对象 HQL检索方式:使用面向对象的HQL ...

  3. Hibernate五 HQL查询

    HQL查询一 介绍1.HQL:Hibernate Query Language,是一种完全面向对象的查询语言.使用Hibernate有多重查询方式可供选择:hibernate的HQL查询,也可以使用条 ...

  4. hibernate的hql查询

    1.概念介绍 1.Query是Hibernate的查询接口,用于从数据存储源查询对象及控制执行查询的过程,Query包装了一个HQL查询语句. 2.HQL是Hibernate Query Langua ...

  5. Hibernate 的hql查询简介【申明:来源于网络】

    Hibernate 的hql查询简介[申明:来源于网络] Hibernate 的hql查询简介:http://blog.csdn.net/leaf_130/article/details/539329 ...

  6. Hibernate的hql语句save,update方法不执行

    Hibernate的hql语句save,update方法不执行 可能出现的原因问题: 未进行事务管理 需要进行xml事务配置或者注解方式的事务配置

  7. Hibernate学习---第九节:Hibernate之hql

    一.Hql 入门 1.实体类: package learn.hibernate.bean; import java.util.Date; import java.util.HashSet; impor ...

  8. Java_Web三大框架之Hibernate+jsp+HQL分页查询

    分页查询无处不在.使用Hibernate+jsp+HQL进行分页查询. 第一步:编写房屋实体类和House.hbm.xml映射. /* * 房屋实体类 */ public class House { ...

  9. Hibernate 查询方式(HQL/QBC/QBE)汇总

    作为老牌的 ORM 框架,Hibernate 在推动数据库持久化层所做出的贡献有目共睹. 它所提供的数据查询方式也越来越丰富,从 SQL 到自创的 HQL,再到面向对象的标准化查询. 虽然查询方式有点 ...

随机推荐

  1. postman测试express restful接口

    安装express及postman var express = require('express') var app = express(); var calculation = require('. ...

  2. ImportError: libQtTest.so.4: cannot open shared

    错误: import cv2 File , in <module> from .cv2 import * ImportError: libQtTest.so.: cannot open s ...

  3. golang中 return如果返回指针比大型struct性能高

    type tt struct{ aa int bb int cc int str string } func func_rstruct () tt{ t:=tt{1,2,3,"8888888 ...

  4. 图论-最近公共祖先-离线Tarjan算法

    有关概念: 最近公共祖先(LCA,Lowest Common Ancestors):对于有根树T的两个结点u.v,最近公共祖先表示u和v的深度最大的共同祖先. Tarjan是求LCA的离线算法(先存储 ...

  5. 浅谈分布式一致性与CAP/BASE/ACID理论

    ##转载请注明 CAP理论(98年秋提出,99年正式发表): C( Consistency)一致性:在分布式系统中,数据一致更新,所有数据变动都是同步的: A( Availability)可用性:分布 ...

  6. ES6 promise简单实现

    基本功能实现: function Promise(fn){ //需要一个成功时的回调 var doneCallback; //一个实例的方法,用来注册异步事件 this.then = function ...

  7. 微软推出ASP.NET Core 2.0,并支持更新Visual Studio 2017

    微软推出ASP.NET Core 2.0的一般可用性,并发布.NET Core 2.0.该公司还推出了其旗舰集成开发环境(IDE)的更新:Visual Studio 2017版本15.3和Visual ...

  8. intellij idea 无法创建类文件,方法。

  9. classpath中怎样一次性加入整个目录的jar文件

    linux可以通过shell来处理 1 2 3 for jar in $HOME/lib/*.jar; do     CLASSPATH=$CLASSPATH:$jar done          

  10. css - 字体图标的制作

    很多的时候我们在开发过程中一般都是直接使用图片,尤其在移动页面频繁请求图片对性能不是很好 ,所以图标字体的应用也越来越广泛.一般情况下直接用的是font awesome字体,但是有时候需要制作自己风格 ...