Cretiria查询应用(二)
1.条件查询,动态查询
public void conditionQuery(){
Session session=null;
try {
session=HibernateUtil.currentSession();
//准备查询条件,对第三方类进行封装
ConditionEmp cm=new ConditionEmp();
cm.setJob("教员");
cm.setSalary(1400D);
cm.setHireDateBegin(ConvertDate.strToDate("2000-11-11", "yyyy-MM-dd"));
cm.setHireDateEnd(ConvertDate.strToDate("2016-11-11", "yyyy-MM-dd"));
//动态添加条件
Criteria c=session.createCriteria(Emp.class);
if(cm.getJob()!=null){
//工作选项不为空
c.add(Restrictions.ilike("job", cm.getJob(), MatchMode.ANYWHERE));
}
if(cm.getSalary()!=0){
c.add(Restrictions.gt("salary", cm.getSalary()));
}
if(cm.getHireDateBegin()!=null){
c.add(Restrictions.ge("hiredate", cm.getHireDateBegin()));
}
if(cm.getHireDateEnd()!=null){
c.add(Restrictions.le("hiredate", cm.getHireDateEnd()));
}
List<Emp> list=c.list();
for (Emp emp : list) {
System.out.println(emp.getName());
}
} catch (Exception e) {
e.printStackTrace();
}finally{
HibernateUtil.closeSession();
}
}
2.排序 分页 关联
public void show(){
Session session=null;
try {
session=HibernateUtil.currentSession();
Criteria c=session.createCriteria(Emp.class);
// //查询工资高于某个范围,结果按照升序或者降序排列
//
// //添加条件
// List<Emp> list= c.add(Restrictions.gt("salary", 1500D)).addOrder(Order.desc("salary")).list();
//
// for (Emp emp : list) {
// System.out.println(emp.getName()+" "+emp.getSalary());
// }
// //工资高于某个范畴,按照工资升序,在按照编号降序
// @SuppressWarnings("unchecked")
// List<Emp> list=c.add(Restrictions.gt("salary", 1500D)).
// addOrder(Order.asc("salary")).
// addOrder(Order.desc("id")).list();
// for (Emp emp : list) {
// System.out.println(emp.getName()+"----"+emp.getSalary()+"----"+emp.getId());
// }
//查出工资最高的两个人
List<Emp> list=c.add(Restrictions.isNotNull("salary")).
addOrder(Order.desc("salary")).
setFirstResult(0).setMaxResults(2).list();
for (Emp emp : list) {
System.out.println(emp.getName()+"----"+emp.getSalary()+"----"+emp.getId());
}
} catch (Exception e) {
e.printStackTrace();
}finally{
HibernateUtil.closeSession();
}
}
3.分页
public void pageDemo(){
Session session=null;
try {
session=HibernateUtil.currentSession();
Criteria c=session.createCriteria(Emp.class);
//获取总记录
Integer count=(Integer) c.setProjection(Projections.rowCount()).uniqueResult();
//设置每页显示几条记录
int pageSize=4;
//计算总页数
int totalPage=(count%pageSize==0)?(count/pageSize):(count/pageSize+1);
//清空查找总记录数时设置的投影
c.setProjection(null);
//页的索引
int pageIndex=1;
//设置从哪条记录开始,不包括输入的值
c.setFirstResult((pageIndex-1)*pageSize);
//设置查找的记录的总条数
c.setMaxResults(pageSize);
List<Emp> list=c.list();
for (Emp emp : list) {
System.out.println(emp.getName());
}
} catch (Exception e) {
e.printStackTrace();
}finally{
HibernateUtil.closeSession();
}
}
4.关联查询
public void joinDemo(){
Session session=null;
try {
session=HibernateUtil.currentSession();
// //查询包含指定字符的员工
// List<Emp> list=session.createCriteria(Emp.class).
// add(Restrictions.ilike("name", "王", MatchMode.ANYWHERE)).
// createCriteria("dept").add(Restrictions.eq("name", "开发部")).list();
// for (Emp emp : list) {
// System.out.println(emp.getName()+" "+emp.getDept().getName());
// }
//查询工作所在地为某一部门的员工人数
List<Dept> list=session.createCriteria(Dept.class,"d").
setFetchMode("emps", FetchMode.JOIN).add(Restrictions.eq("d.name", "开发部")).list();
System.out.println(list.size());
} catch (Exception e) {
e.printStackTrace();
}finally{
HibernateUtil.closeSession();
}
}
5.投影
public void projectionDemo(){
Session session=null;
try {
session=HibernateUtil.currentSession();
// //查询员工的姓名和入职时间
// List<Object[]> list=session.createCriteria(Emp.class).
// setProjection(Projections.projectionList().
// add(Property.forName("name")).
// add(Property.forName("hiredate")))
// .list();
// for (Object[] obj : list) {
// System.out.println(obj[0]+" "+obj[1]);
// // new Date(((Timestamp)obj[1]).getTimestamp());
// }
// //统计各部门的平均工资、最高工资、最低工资
// List<Object[]> list=session.createCriteria(Emp.class,"e").
// createAlias("e.dept", "d").
// setProjection(Projections.projectionList().
// add(Projections.groupProperty("d.name")).
// add(Projections.avg("salary")).
// add(Projections.max("salary")).
// add(Projections.min("salary"))).list();
// for (Object[] obj : list) {
// System.out.println(obj[0]+" "+obj[1]+" "+obj[2]+" "+obj[3]);
// }
//使用DetachedCriteria
DetachedCriteria dc=DetachedCriteria.forClass(Emp.class,"e")
.createAlias("e.dept", "d").add(Restrictions.eq("d.name", "人事部"))
.add(Restrictions.ilike("e.name", "王",MatchMode.ANYWHERE));
//查询数据
List<Emp> list= dc.getExecutableCriteria(session).list();
for (Emp emp : list) {
System.out.println(emp.getName()+"---"+emp.getDept().getName());
}
} catch (Exception e) {
e.printStackTrace();
}finally{
HibernateUtil.closeSession();
}
}
Cretiria查询应用(二)的更多相关文章
- 第四章 MySQL高级查询(二)
第四章 MySQL高级查询(二) 一.EXISTS子查询 在执行create 或drop语句之前,可以使用exists语句判断该数据库对像是否存在,返回值是true或false.除此之外,exists ...
- SQL基础--查询之二--连接查询
SQL基础--查询之二--连接查询
- MySQL慢查询(二) - pt-query-digest详解慢查询日志 pt-query-digest 慢日志分析
随笔 - 66 文章 - 0 评论 - 19 MySQL慢查询(二) - pt-query-digest详解慢查询日志 一.简介 pt-query-digest是用于分析mysql慢查询的一个工具,它 ...
- 每天玩转3分钟 MyBatis-Plus - 4. 高级查询(二)(条件构造器)
每天玩转3分钟 MyBatis-Plus - 1. 配置环境 每天玩转3分钟 MyBatis-Plus - 2. 普通查询 每天玩转3分钟 MyBatis-Plus - 3. 高级查询(一) 每天玩转 ...
- SQL Server-聚焦UNIOL ALL/UNION查询(二十三)
前言 本节我们来看看有关查询中UNION和UNION ALL的问题,简短的内容,深入的理解,Always to review the basics. 初探UNION和UNION ALL 首先我们过一遍 ...
- solr多条件查询(二)
由于现在的 需求很变态需要N多条件的叠加,本人就用了一天时间摸索加求助,终于参透出这个q和fq的强大之处. 需求如下图,有三种关系:并且.或.不含 1.如果是或者也就是改变的q的查询条件: 2.如果是 ...
- Mysql查询(笔记二)
1.两结构相同的表数据间移植 Inset into 表一 Select 字段1,字段2,....字段n from表二 建立数据库时设置数据库编码 create database 数据库名 charse ...
- MySQL慢查询(二) - pt-query-digest详解慢查询日志
一.简介 pt-query-digest是用于分析mysql慢查询的一个工具,它可以分析binlog.General log.slowlog,也可以通过SHOWPROCESSLIST或者通过tcpdu ...
- Hibernate(十三):HQL查询(二)
背景 基于上一章节<Hibernate(十二):HQL查询(一)>,已经学习了一部分关于HQL的用法: HQL带参数查询 HQL Order By排序查询 HQL 设置实体参数查询 本章节 ...
随机推荐
- 持续集成环境(Gitlab+jenkins+shell)
一.搭建gitlab ps:不是这方面的专家,主要还是一键式安装为主. 1.进入官网:https://about.gitlab.com/gitlab-com/ 2.选择自己的操作系统:我这边选择的ub ...
- C++ Const成员函数
一些成员函数改变对象,一些成员函数不改变对象. 例如: int Point::GetY() { return yVal; } 这个函数被调用时,不改变Point对象,而下面的函数改变Point对象 ...
- xdebug使用说明
常用配置 xdebug.var_display_max_children整数类型,默认值128.用于控制通过xdebug_var_dump(),var_dump()方法时显示数组中子数组的个数或对象中 ...
- node学习笔记-搭建node环境
最近项目要用到node,利用空闲整理做下笔记 第一步 安装node,方式比较多,最为直接的是直接去官网 可直接从官网下载安装http://nodejs.cn/download/ 根据自己情况 ...
- 图片输出onerror事件
<img src=".<?php echo $img[0];?>" onerror="this.src='img/zanwu.jpg'" st ...
- Android Init语言
Android Init语言是一种特别简单的语言,专门用来写Android的Init进程使用的配置文件的. 相当于Linux系统中的rc文件(这句话对于Linux者多半是句废话). Android I ...
- lnmp下安装ffmpeg和ffmpeg-php教程
现在我将我的过程方法发布出来. 以下都是用SSH命令 一.安装ffmpeg 操作系统:centos6 安装ffmpeg有两种方式:①.用源码包安装,这个不知道怎么回事老是报错②用yum命令安装,cen ...
- php读取memcache二进制数据
memcache作为一个数据中间层,经常用来做数据交换. 比如在某个系统内部我们规定如下的用户状态的信息,每个用户只需要存续52个字节. Key state#ID 如”state#10888” Val ...
- 无效的过程调用或参数: 'Instr'解决方法
以前我一直使用ASP无组件上传类来上传文件.但是今天又个客户反映说.不能上传.出现错误.,但在我电脑上测试没问题.后来发现客户用的是IE8 于是开始找解决方法 错误如下:Microsoft VBScr ...
- 【转】关于FPGA中建立时间和保持时间的探讨
时钟是整个电路最重要.最特殊的信号,系统内大部分器件的动作都是在时钟的跳变沿上进行, 这就要求时钟信号时延差要非常小, 否则就可能造成时序逻辑状态出错:因而明确FPGA设计中决定系统时钟的因素,尽 ...