项目中用到了criteria的查询方式,觉得挺好用的,下班后找了一下资料,一边测试,一边在博客上面记录下来

如何使用

查所有

  /**
* 作用:查所有
* 说明:通过list(),返回的是实体对象集合
*/
@Test
public void test1(){
//创建连接
Session session = HibernateUtil.getCurrentSession();
//开启事务
Transaction tx = session.beginTransaction();
//创建criteria
Criteria criteria = session.createCriteria(User.class, "u");
//业务
List<User> list = criteria.list();
for (User user : list) {
System.out.println(user);
}
//关闭事务
session.close();
}

条件查询

  1)一个条件

/**
* 作用:or()用法
* 说明:通过or()返回的是实体对象集合
* add(Criterion criterion)用来添加查询条件
* Restrictions通过内置的静态方法,可以创建criterion
*/
//创建criteria
Criteria criteria = session.createCriteria(User.class, "u");
//业务:查询出id为1或为2的用户
List<User> list = criteria.add(Restrictions.or(Restrictions.eq("id", 1),
Restrictions.eq("id", 2) ))
.list();

  2)多个条件

  /**
* 作用:多个条件:like()和gt()的用法
*/
//创建criteria
Criteria criteria = session.createCriteria(User.class, "u");
//业务:查询出id大于1,名字中带ji的用户
List<User> list = criteria.add(Restrictions.like("name","%ji%"))
.add(Restrictions.gt("id", 1))
.list();

其他的条件就不一一测试了,下面列出常用的Restrictions方法

  Restrictions.eq 等于
  Restrictions.allEq 使用Map,使用key/value进行多个等于的比对
  Restrictions.gt 大于 >
  Restrictions.ge 大于等于 >=
  Restrictions.lt 小于 <
  Restrictions.le 小于等于 <=
  Restrictions.between 对应SQL的BETWEEN子句
  Restrictions.like 对应SQL的LIKE子句
  Restrictions.in 对应SQL的in子句
  Restrictions.and and关系
  Restrictions.or or关系

排序

  /**
* 作用:排序
* 说明:通过addOrder()添加排序条件
* Order设置排序规则,desc是降序,asc是升序
*/
//创建criteria
Criteria criteria = session.createCriteria(User.class, "u");
//业务:对查询结果,根据id排序
List<User> list = criteria.addOrder(Order.desc("id"))
.list();

关联

参考 : http://blog.csdn.net/bestlxm/article/details/6735464   

User实体类中有关系属性orders,

数据库中的数据如下:order表中的外键是user_id

  user表:

order表:

代码如下:

/**
* 作用:关联
* 说明:通过createAlias()设置关系属性
* 对已定义关联关系的,我们可以使用createAlias()来创建属性的别名,然后引用别名进行条件查询,如:
这样进行查询时就可得到关联查询后的Parent对象结果集,本例中,User是Parent类
*
* Hibernate打印sql语句如下:
* select
this_.id as id0_1_,
this_.age as age0_1_,
this_.birth as birth0_1_,
this_.name as name0_1_,
o1_.id as id1_0_,
o1_.note as note1_0_,
o1_.price as price1_0_
from
user50 this_
inner join
order50 o1_
on this_.id=o1_.user_id
where
o1_.id = ? * 控制台打印如下:
* User [userID=1, name=zhangjifeng, age=18, birthday=2016-07-26]
*/
@Test
public void test5(){
//创建连接
Session session = HibernateUtil.getCurrentSession();
//开启事务
Transaction tx = session.beginTransaction();
//创建criteria
Criteria criteria = session.createCriteria(User.class, "u");
//业务:
List<User> list = criteria.createAlias("orders","o")
.add(Restrictions.eq("o.id", 1))
.list();
for (User user : list) {
System.out.println(user);
} //关闭事务
session.close();
}

关联2:createCriteria()

测试代码如下

  /**
* 第二个createCriteria(),返回的是一个新的实例
* 打印出user和order
*/
@Test
public void test6(){
//创建连接
Session session = HibernateUtil.getCurrentSession();
//开启事务
Transaction tx = session.beginTransaction();
//创建criteria
Criteria criteria = session.createCriteria(User.class, "u");
//业务:
List list = criteria.createCriteria("orders","o")
.add(Restrictions.eq("o.id", 1))
.setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)
.list();
Iterator iterator = list.iterator();
while (iterator.hasNext()) {
Map map = (Map)iterator.next(); // Set keySet = map.keySet(); Set entrySet = map.entrySet();
Iterator iterator2 = entrySet.iterator();
while(iterator2.hasNext()){
Map.Entry<String, Object> map1 =(Entry<String, Object>) iterator2.next();
System.out.println(map1.getValue());
}
}
//关闭事务
session.close();
}

Projections投影

1)将结果集中的结果当做行和列集来使用,这与通过JDBC执行select查询获得的数据的使用方式相似。因此,Hibernate也支持属性、统计函数和Group By等查询。

2)要想使用Hibernate的投影统计功能,首先要从org.hibernate.criterion.Projections工厂类获得org.hibernate.criterion.Projection对象

3)Hibernate的Projections工厂类包含了以下几个常用的统计函数:

    ① avg(String propertyName):计算属性字段的平均值。

    ② count(String propertyName):统计一个属性在结果中出现的次数。

    ③ countDistinct(String propertyName):统计属性包含的不重复值的数量。

    ④ max(String propertyName):计算属性值的最大值。

    ⑤ min(String propertyName):计算属性值的最小值。

    ⑥ sum(String propertyName):计算属性值的总和。

代码如下:

/**
* 投影:Projections
* 统计,重复
*/
@Test
public void test8(){
//创建连接
Session session = HibernateUtil.getCurrentSession();
//开启事务
Transaction tx = session.beginTransaction();
//创建criteria
Criteria criteria = session.createCriteria(Order.class, "o");
//业务:
List<Object[]> list = criteria.setProjection(Projections.projectionList()
.add(Projections.max("price"))
.add(Projections.min("price"))
.add(Projections.avg("price"))
.add(Projections.countDistinct("note")) )
.list();
for (Object[] objects : list) {
for (Object object : objects) {
System.out.println(object);
}
}
//关闭事务
session.close();

获得的结果是单独的属性而不是实体类。例如,一个产品表中包含有很多字段,我们想要获取产品表中的名称和描述,而不需要将完整的实体加载到内存中

  /**
* 投影:Projections
* 获取部分字段
*/
@Test
public void test9(){
//创建连接
Session session = HibernateUtil.getCurrentSession();
//开启事务
Transaction tx = session.beginTransaction();
//创建criteria
Criteria criteria = session.createCriteria(Order.class, "o");
//业务:
ProjectionList projList = Projections.projectionList();
projList.add(Projections.property("name"));
projList.add(Projections.property("price"));
criteria.setProjection(projList);
List result = criteria.list();
for (Object object : result) {
System.out.println(object);
}
//关闭事务
session.close();
}

hibernate的Criteria条件查询的更多相关文章

  1. Hibernate中的条件查询完成类

    Hibernate中的条件查询有以下三个类完成: 1.Criteria:代表一次查询 2.Criterion:代表一个查询条件 3.Restrictions:产生查询条件的工具类

  2. 分享知识-快乐自己:Hibernate 中Criteria Query查询详解

    1):Hibernate 中Criteria Query查询详解 当查询数据时,人们往往需要设置查询条件.在SQL或HQL语句中,查询条件常常放在where子句中. 此外,Hibernate还支持Cr ...

  3. Hibernate中的条件查询完毕类

    Hibernate中的条件查询有下面三个类完毕: 1.Criteria:代表一次查询 2.Criterion:代表一个查询条件 3.Restrictions:产生查询条件的工具类

  4. Hibernate 中Criteria Query查询详解【转】

    当查询数据时,人们往往需要设置查询条件.在SQL或HQL语句中,查询条件常常放在where子句中.此外,Hibernate还支持Criteria查询(Criteria Query),这种查询方式把查询 ...

  5. Nhibernate Query By Criteria 条件查询

    HQL运算符 QBC运算符 含义 = Restrictions.eq() 等于equal <> Restrictions.ne() 不等于not equal > Restrictio ...

  6. Hibernate 日期映射 条件查询

    1. hql: ...and accopt_time > ?" 2. query.setDate Query query = session.createQuery(hql); int ...

  7. Hibernate QBC 条件查询(Criteria Queries) and Demos

    目录 创建一个Criteria 实例 限制结果集内容 结果集排序 关联 动态关联抓取 查询示例 投影Projections聚合aggregation和分组grouping 离线detached查询和子 ...

  8. hibernate Criteria(条件查询接口)

    Criteria(条件查询接口) // 1.简单查询 List<Customer> list = session.createCriteria(Customer.class).list() ...

  9. Hibernate条件查询

    设计上可以灵活的根据 Criteria 的特点来方便地进行查询条件的组装.现在对 Hibernate的Criteria 的用法进行总结:Hibernate 设计了 CriteriaSpecificat ...

随机推荐

  1. AC日记——求10000以内n的阶乘 openjudge 1.6 14

    14:求10000以内n的阶乘 总时间限制:  5000ms 内存限制:  655360kB 描述 求10000以内n的阶乘. 输入 只有一行输入,整数n(0<=n<=10000). 输出 ...

  2. 给VIM安装插件。让ubuntu的vim强大起来

    简易安装方法: 打开终端,执行下面的命令就自动安装好了: wget https://raw.github.com/ma6174/vim/master/setup.sh -O ma6174_vim_se ...

  3. [转]MVC整合Ajax

    MVC教程第五篇:MVC整合Ajax   2010-02-01 作者:张洋 来源:张洋的BLOG   摘要 本文将从完成“输入数据验证”这个功能出发,逐渐展开ASP.NET MVC与Ajax结合的方法 ...

  4. java 28 - 3 设计模式之 装饰设计模式

    装饰设计模式 装饰设计模式概述 装饰模式就是使用被装饰类的一个子类的实例,在客户端将这个子类的实例交给装饰类.是继承的替代方案 优点 使用装饰模式,可以提供比继承更灵活的扩展对象的功能,它可以动态的添 ...

  5. java 25 - 2 网络编程之 网络通信三要素

    网络通信三要素 IP地址: InetAddress 网络中设备的标识,不易记忆,可用主机名(计算机的标识号) 端口号: 用于标识进程的逻辑地址,不同进程的标识(正在运行的软件的标识号) 传输协议: 通 ...

  6. java 22 - 10 多线程之两种代码实现方式的比较与区别

  7. HTML 学习笔记 JavaScript (实现)

    HTML中的脚本 必须位于<script></script>标签之间 脚本可被放置在HTML页面的<body>和<head>部分中 <script ...

  8. IntelliJ IDEA运行tomcat项目编码错误, 及如何指定tomcat编码

    刚开始用IDEA, 在跑dubbo开发时, 发现一个很奇怪的问题, 远程调用服务端的方法时, 传入的中文参数会变成GBK编码. 经过好长时间的跟踪终于把问题定位到了IDEA里配置的Tomcat. 凡是 ...

  9. 批量去除Teleport Pro整站下载文件冗余代码

    teleport pro tppabs标签批量删除 teleport pro tppabs标签批量删除 使 用Teleport Pro下载的网页代码中包含了很多垃圾代码,比如下载的html网页代码中会 ...

  10. 重构Web Api程序(Api Controller和Entity)续篇

    昨天有写总结<重构Web Api程序(Api Controller和Entity)>http://www.cnblogs.com/insus/p/4350111.html,把一些数据交换的 ...