Criteria、Criterion接口和Expression类组成,他支持在运行时动态生成查询语句。

Criteria查询是Hibernate提供的一种查询方式

Hibernate检索方式:  PO=JavaBean+xml  OID

Hibernate提供了5种检索对象的方式

1.导航对象图检索方式:根据已经加载的对象导航到其他对象

from  Emp e group by e.dept.deptName

2.OID检索方式:按照对象的OID来检索对象  get/load

3.HQL检索方式:使用面向对象的HQL查询语言

4.QBC检索方式:使用QBC(Query By Criteria)API来检索对象,这种API封装了基于字符串形式的查询语句,提供了更加面向对象的查询接口

5.本地SQL检索方式:使用本地数据库的SQL查询语句

createSqlQuery();

本文案例提供类:Emp、Dept

当前案例中所有Criteria查询条件类型皆为Criterion类型  即Restrictions为我们提供的这些静态方法返回值类型皆返回Criterion类型

Restrictions

1.简单的查询    条件查询员工信息

 public void Test1(){
Criteria criteria = session.createCriteria(Emp.class);
criteria.createAlias("dept","d");
Criterion criterion= Restrictions.eq("d.deptName", "SALES");
criteria.add(criterion);
List<Emp> list = criteria.list();
for (Emp emp : list) {
System.out.println(emp.getEmpName());
}
}

解析: 其中使用Restrictions的eq方法   找出数据库中deptName列中名字叫做sales的员工

2.字符串模糊匹配

 public void Test2(){
Criteria criteria=session.createCriteria(Emp.class);
//like 字符串模式匹配 iLike:字符串模式匹配,同时忽略大小写
Criterion criterion = Restrictions.like("empName", "S",MatchMode.EXACT); //其中exact是指精确匹配
criteria.add(criterion);
List<Emp> list = criteria.list();
for (Emp emp : list) {
System.out.println(emp.getEmpName());
}
tx.commit();
}

解析:Restrictions类提供了几个静态类让我们使用     此处就是使用了like()方法来查询出员工名字是S的人。

     第三个参数是MatchMode提供的静态常亮用于指定字符串模式匹配   取值分别有:

 start      员工姓名以S 开头
end 员工姓名以S 结尾
anywhere 员工姓名中包含S即可
exact 员工姓名是S(用于精确匹配)

3.范围运算符

    public void test4(){
Criteria criteria=session.createCriteria(Emp.class);
//将bj和sh放入List<String>
List<String> job=new ArrayList<String>();
job.add("MANAGER");
//citys.add("sh");
Criterion criterion = Restrictions.in("job",job);
criteria.add(criterion);
List<Emp> list = criteria.list(); for (Emp emp: list) {
System.out.println(emp.getEmpName());
} tx.commit();
}

解析:将查询条件放入List<String>  泛型中   使用Restrictions的in方法来查询符合条件的员工信息

4.连接查询

 public void test5(){
Session session = HibernateUtil.getSession();
Transaction tx=session.beginTransaction();
Criteria criteria = session.createCriteria(Emp.class);
criteria.createAlias("dept", "d");
Criterion criterion = Restrictions.eq("d.deptName", "财务部");
criteria.add(criterion);
List<Emp> list = criteria.list();
for (Emp dept : list) {
System.out.println(dept.getEmpName());
}
tx.commit();
}

解析:给Emp类中dept属性通过createAlias(“关联属性的路径  一般是类型的某个外键属性”,“别名”)方法设置别名为"d"     然后通过dept中的deptName属性来查找相应数据。

5.逻辑运算(给criteria添加多个匹配条件)

     public void Test3(){
Criteria criteria=session.createCriteria(Emp.class);
Criterion criterion1 = Restrictions.eq("job", "MANAGER");
Criterion criterion2 = Restrictions.ilike("empName", "C",MatchMode.ANYWHERE);
Criterion and = Restrictions.disjunction().add(criterion2).add(criterion1);//(criterion1,criterion2)
criteria.add(and);
List<Emp> list = criteria.list();
for (Emp emp : list) {
System.out.println(emp.getEmpName());
}
tx.commit();
}

解析:   Restrictions.and()   该方法返回的依然是条件   需要再次的通过criteria.add(and)   方法将其添加到其中。Disjunction()方法加入多个条件的逻辑或操作。

6.排序

 public void test9(){
Session session = HibernateUtil.getSession();
Transaction tx=session.beginTransaction();
Criteria criteria=session.createCriteria(Emp.class);
Criterion criterion= Restrictions.gt("empId",); criteria.add(criterion).addOrder(Order.asc("empId"));
List<Emp> list = criteria.list();
for (Emp emp : list) {
System.out.println(emp.getEmpName());
}
tx.commit();
}

解析:当前案例同过add()方法添加了查询条件后,再通过addOrder()方法通过指定的列进行正向排序。

7.集合运算

        public void collectionTest(){
Criteria criteria = session.createCriteria(Dept.class); Criterion criterion = Restrictions.isEmpty("emps"); criteria.add(criterion); List<Dept> list = criteria.list();
for (Dept dept : list) {
System.out.println(dept.getDeptName());
}
}

解析:通过判断当前部门下的员工集合是否为空来进行集合运算     上面的操作:是查找出所有员工集合为空的部门名称

8.动态查询

 public void dynamicTest(){
Criteria criteria = session.createCriteria(Emp.class);
//00.构建出一个和page对应的条件类,依次判定条件是否为空
EmpCondition condition=new EmpCondition();
condition.setEmpCity("bj");
condition.setEmpId(); //1.2判定之后,动态拼接检索条件
if (condition.getEmpCity()!=null) {
//用户填写了地址作为检索条件
criteria.add(Restrictions.eq("empCity", condition.getEmpCity()));
}
if(condition.getEmpId()!=null){
//用户填写用户编号作为筛选条件
criteria.add(Restrictions.gt("empId", condition.getEmpId()));
}
List<Emp> list = criteria.list();
for (Emp emp : list) {
System.out.println(emp.getEmpName());
}
}

解析:通过扩展类将查询的具体属性封装起来,可以添加多个匹配条件来查询数据

9.分页

 public void test10(){
Session session = HibernateUtil.getSession();
Transaction tx=session.beginTransaction();
Criteria criteria=session.createCriteria(Emp.class);
Projection projection = Projections.count("empId");
criteria.setProjection(projection);
//求出总记录数
Integer count = ((Long)criteria.uniqueResult()).intValue();
int pageSize=3;
int pageIndex=2;
Criteria criteria2=session.createCriteria(Emp.class);
//数据的拎取
criteria2.setFirstResult((pageIndex-1)*pageSize);
criteria2.setMaxResults(pageSize);
List<Emp> list = criteria2.list();
for (Emp emp : list) {
System.out.println(emp.getEmpName());
}
tx.commit();
}

解析:

Criteria接口提供了设置分页的方法

setFirstResult(int firstResult)  起始记录的索引

setMaxResult(int maxResult)  最大记录条数

10.DetachedCriteria 查询

  DetachedCriteria 创建时不需要Session对象。适用于有大量动态条件查询,即用户在网页上自由选择某些条件,程序根据用户的选择条件,动态生成SQL语句,进行查询。

  针对这种需求,对于分层应用程序来说,文本层需要传递一个查询的条件列表给业务层对象,业务层对象获得这个条件列表 之后,依次取出条件,构造查询语句。

  查询结果也可作为查询条件:例如当查询结果为平均成绩时,就可以其他成绩来和平均成绩做对比。

 /**
* 1.11 DetachedCriteria和Criteria功能类似,它实现了CriteriaSpecification接口
Criteria是由Session对象创建的
DetachedCriteria创建时不需要Session对象
使用DetachedCriteria来构造查询条件
可以把DetachedCriteria作为方法参数传递给业务层
* 查询开发部的员工
* */
@Test
public void detachedCriteriaTest(){
//难度 3颗星 重要程度五颗星 ★★★★★
//1.构建一个Detached对象
DetachedCriteria detachedCriteria=DetachedCriteria.forClass(Emp.class);
//1.2 别名
detachedCriteria.createAlias("dept", "d");
//1.3 指定检索条件
Criterion criterion = Restrictions.eq("d.deptName", "开发部");
//bind 绑定
detachedCriteria.add(criterion);
//detachedCriteria的方法植入对session的引入 List<Emp> list = detachedCriteria.getExecutableCriteria(session).list(); for (Emp emp : list) {
System.out.println(emp.getEmpName());
}
} }

Criteria 查询的更多相关文章

  1. Hibernate框架之Criteria查询 和注解(重点☆☆☆☆☆,难点☆☆☆)

    写好一篇博客,不是容易的事.原因是:你要给自己以后看的时候,还能看懂,最重要的是当别人看到你的博客文章的时候,也一样很清楚的明白你自己写的东西.其实这也是一种成就感!! 对于每一个知识点,要有必要的解 ...

  2. NHibernate系列文章二十三:NHibernate查询之Criteria查询(附程序下载)

    摘要 上一篇文章介绍了NHibernate HQL,他的缺点是不能够在编译时发现问题.如果数据库表结构有改动引起了实体关系映射的类有改动,要同时修改这些HQL字符串.这篇文章介绍NHibernate面 ...

  3. Criteria查询初学者的采纳点哦

    一.Hibernate提供了5种检索对象的方式 1.导航对象图检索方式:根据已经加载的对象导航到其他对象    from  Emp e group by e.dept.deptName 2.OID检索 ...

  4. Criteria查询之sqlRestriction()的理解

    sqlRestriction()的理解 在Criteria查询中 使用sqlRestriction()方法来提供SQL语法作限定查询,作为where字句 查看官方给的例子,如下 List cats = ...

  5. Criteria查询数据

    Criteria介绍: Criteria查询是Hibernate提供的一种查询方式,与HQL基于字符串的查询形式完全不同.Hibernate提供了org.hiberanee.Criteria 接口.o ...

  6. Hibernate框架之Criteria查询

    首先给大家说说Hibernate检索方式 Hibernate提供了5种检索对象的方式 1.导航对象图检索方式:根据已经加载的对象导航到其他对象 2.OID检索方式:按照对象的OID来检索对象 3.HQ ...

  7. Hibernate 、Hql查询和Criteria查询

    HQL查询: public Object query(String name){ Session s=null; try{ s=HibernateSessionFactory.getSession() ...

  8. Hibernate框架Criteria查询

    本文章适合一些初学者 一.使用Criteria查询数据        1.条件查询            1.1:使用Criteria查询的步骤                    1.使用Sess ...

  9. 第九章 Criteria查询及注解

    第九章   Criteria查询及注解9.1 使用Criteria查询数据    9.1.1 条件查询        Criteria查询步骤:            1)使用session接口的cr ...

  10. hibernate框架学习笔记7:HQL查询、Criteria查询简介

    HQL查询:hibernate独有的查询语言 适用于不复杂的多表查询 示例: 实体类: package domain; public class Customer { private Long cus ...

随机推荐

  1. 【11】AngularJS HTML DOM

    AngularJS HTML DOM AngularJS 为 HTML DOM 元素的属性提供了绑定应用数据的指令. ng-disabled 指令 ng-disabled 指令直接绑定应用程序数据到 ...

  2. Minimum Sum LCM(uva 10791)

    题意(就是因为读错题意而wa了一次):给一个数字n,范围在[1,2^23-1],这个n是一系列数字的最小公倍数,这一系列数字的个数至少为2 例如12,是1和12的最小公倍数,是3和4的最小公倍数,是1 ...

  3. CF578D. LCS Again

    n<=100000个字符的小写字母串,问用前m<=26个小写字母能拼出多少个和原串lcs=n-1的字符串. 首先把字符串划分成若干个连续相同的段,如aaa|bb|c|dd,然后题目即要求从 ...

  4. vijos 1439 区间

    区间 背景 描述 给定n个闭区间 [ai,bi], i=1,2,...,n. 这些区间的和可以用两两不相交的闭区间的和来表示.你的任务是找到这样的区间数目最少的表示,且把它们按升序的方式写到输出文件中 ...

  5. - > 听学姐讲那过去的故事——打代码的小女孩

    童话故事 不知道大家有没有看过  天冷极了,下着雪,又快黑了.这是一年的最后一天——大年夜.在这又冷又黑的晚上,一个乖巧的小女孩在机房里调试程序.她从家里出来的时候还穿着一件外套,但是有什么用呢?那是 ...

  6. - > 动规讲解基础讲解一——01背包(模板)

    作为动态规划的基础,01背包的思想在许多动规问题中会经常出现,so,熟练的掌握01背包的思路是极其重要的: 有n件物品,第i件物品(I = 1,2,3…n)的价值是vi, 重量是wi,我们有一个能承重 ...

  7. RDLC报表总结

    这2天纠结的报表基本上已近完成大部分功能.现在总结一下自己近期的学习成果 首先制作微软RDLC报表由以下三部分构成:1.制作自己的DateSet集合(就是报表的数据集):2.制作自己的报表文件.rdl ...

  8. 一份关于jvm内存调优及原理的学习笔记(转)

    JVM 一.虚拟机的基本结构 1.jvm整体架构 类加载子系统:负责从文件系统或者网络中加载class信息,存入方法区中. 方法区(Perm):存放加载后的class信息,包括静态方法,jdk1.6以 ...

  9. vsftpd conf 解釋

    Linux中vsFTP位置约定:/usr/sbin/vsftpd ---- VSFTPD的主程序/etc/rc.d/init.d/vsftpd ---- 启动脚本/etc/vsftpd/vsftpd. ...

  10. 微信前端js sdk以外的开发

    此时页面中就会出现刚才我画红圈部分的工具条. 这个工具条再加上上面的标题栏工具条. 极大的降低了可视区域的面积. 是否能将它去掉呢?答案是能够的.增加以下代码就能够去掉微信中以下的工具条: docum ...