聚合函数:

实例:

package Test;

import static org.junit.Assert.*;

import java.util.List;

import org.hibernate.Session;
import org.junit.Test; import entity.AvgSal; import util.HibernateSessionFactory;
import util.HibernateUtil; public class AggTest { /**
* 统计部门个数。
*/
@Test
public void test1() {
Session session =HibernateSessionFactory.getSession();
try {
Long count = (Long) session.createQuery("select count(d) from Dept d").uniqueResult();
System.out.println("共有"+count+"个部门。");
} catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
} /**
* 统计员工工资。
*/
@Test
public void test2() {
Session session =HibernateSessionFactory.getSession();
try {
Double totalsal = (Double) session.createQuery("select sum(e.sal) from Emp e").uniqueResult();
System.out.println("员工工资总数为:"+totalsal);
} catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
} /**
* 统计员工最低工资。
*/
@Test
public void test3() {
Session session =HibernateSessionFactory.getSession();
try {
Double minsal = (Double) session.createQuery("select min(e.sal) from Emp e").uniqueResult();
System.out.println("员工工资最低为:"+minsal);
} catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
} /**
* 统计员工最高工资。
*/
@Test
public void test4() {
Session session =HibernateSessionFactory.getSession();
try {
Double maxsal = (Double) session.createQuery("select max(e.sal) from Emp e").uniqueResult();
System.out.println("员工工资最高为:"+maxsal);
} catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
}
/**
* 统计员工平均工资。
*/
@Test
public void test5() {
Session session =HibernateSessionFactory.getSession();
try {
Double avgsal = (Double) session.createQuery("select avg(e.sal) from Emp e").uniqueResult();
System.out.println("员工平均工资为:"+avgsal);
} catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
}
/**
* 统计最低工资、最高工资以及平均工资。
*/
@Test
public void test6() {
Session session =HibernateSessionFactory.getSession();
try {
List<Object[]> list = session.createQuery("select min(e.sal),max(e.sal),avg(e.sal) from Emp e").list();
for (Object[] objects : list) {
Double minsal=(Double) objects[0];
Double maxsal=(Double) objects[1];
Double avgsal=(Double) objects[2];
System.out.println("最低工资为:"+minsal+",最高工资为:"+maxsal+",平均工资为:"+avgsal);
}
} catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
}
/**
* 统计员工职位个数。
*/
@Test
public void test7() {
Session session =HibernateSessionFactory.getSession();
try {
Long jobcount = (Long) session.createQuery("select count(distinct e.job) from Emp e").uniqueResult();
System.out.println("共有"+jobcount+"种职位");
} catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
} /**
* 按职位统计员工个数。
*/
@Test
public void test8() {
Session session =HibernateSessionFactory.getSession();
try {
List<Object[]> list = session.createQuery("select job,count(ename) from Emp group by job").list();
System.out.println("按职位统计员工个数");
for (Object[] objects : list) {
String job=(String) objects[0];
Long count=(Long) objects[1];
System.out.println(job+"职位======"+count+"个员工");
} } catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
} /**
* 统计各个部门的平均工资
*/
@Test
public void test9() {
Session session =HibernateSessionFactory.getSession();
try {
List<Object[]> list = session.createQuery("select job,avg(sal) from Emp group by job").list();
System.out.println("按职位统计每个职位员工的平均工资");
for (Object[] objects : list) {
String job=(String) objects[0];
Double avg=(Double) objects[1];
System.out.println(job+"职位平均工资是======"+avg);
} } catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
}
/**
* 统计各个职位的最低工资和最高工资
*/ @Test
public void test10() {
Session session =HibernateSessionFactory.getSession();
try {
List<Object[]> list = session.createQuery("select job,max(sal),min(sal) from Emp group by job").list();
System.out.println("统计各个职位的最低工资和最高工资");
for (Object[] objects : list) {
String job=(String) objects[0];
Double max=(Double) objects[1];
Double min=(Double) objects[2];
System.out.println(job+"职位最高工资是======"+max+",最低工资是:===="+min);
} } catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
} /**
* 统计各个部门平均工资高于2000元的部门名称,打印部门名称、部门平均工资
*/
@Test
public void test11() {
Session session =HibernateSessionFactory.getSession();
try {
List<Object[]> list = session.createQuery("select dept.dname,avg(sal) from Emp group by dept.dname having avg(sal)>2000").list();
System.out.println("统计各个部门平均工资高于2000元的部门名称,打印部门名称、部门平均工资");
for (Object[] objects : list) {
String dept=(String) objects[0];
Double avg=(Double) objects[1];
System.out.println(dept+"\t"+avg);
} } catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
}
/**
* 统计各个部门平均工资高于2000元的部门名称,打印部门名称、部门平均工资,使用JavaBean封装查询结果
*/
@Test
public void test12() {
Session session =HibernateSessionFactory.getSession();
try {
List<AvgSal> list = session.createQuery("select new entity.AvgSal(dept.dname,avg(sal) )from Emp group by dept.dname having avg(sal)>2000").list();
System.out.println("统计各个部门平均工资高于2000元的部门名称,打印部门名称、部门平均工资,使用JavaBean(entity.AvgSal)封装查询结果");
for (AvgSal avgSal : list) {
System.out.println(avgSal.getDname()+"\t"+avgSal.getAvgsal());
} } catch (Exception e) {
e.printStackTrace();
System.out.println("失败");
}
} }

hibernate-聚合函数分组统计数据查询的更多相关文章

  1. 18 12 06 sql 的 基本语句 查询 条件查询 逻辑运算符 模糊查询 范围查询 排序 聚合函数 分组 分页 连接查询 自关联 子查询

    -- 数据的准备 -- 创建一个数据库 create database python_test charset=utf8; -- 使用一个数据库 use python_test; -- 显示使用的当前 ...

  2. Django orm进阶查询(聚合、分组、F查询、Q查询)、常见字段、查询优化及事务操作

    Django orm进阶查询(聚合.分组.F查询.Q查询).常见字段.查询优化及事务操作 聚合查询 记住用到关键字aggregate然后还有几个常用的聚合函数就好了 from django.db.mo ...

  3. hibernate学习系列-----(5)hibernate基本查询下篇:hibernate聚合函数、分组查询及命名查询

    在上一篇中,大致学习了hibernate的基本查询:HQL基本查询,今天,继续昨天的步伐,继续学习hibernate的基本查询..... 1.hql聚合函数,先大致列一下hql的聚合函数有哪些吧: 在 ...

  4. sql server 分组统计数据

    说明:group by是sql中对数据表中的数据进行分组的,在select列表中出现的字段必须全部出现在group by 字段中,出现在聚合函数中的字段在group by中可有可无,没有出现在sele ...

  5. java:Oracle(聚合函数,多表查询,表之间的关系)

    1.聚合函数 --max,min,sum,avg,count,nvl(,) -- max:最大值 -- max既能取数字的最大值,也可以取字符串的最大值(英文字母排列顺序),根据场景实际意义来看,最好 ...

  6. ES 24 - 如何通过Elasticsearch进行聚合检索 (分组统计)

    目录 1 普通聚合分析 1.1 直接聚合统计 1.2 先检索, 再聚合 1.3 扩展: fielddata和keyword的聚合比较 2 嵌套聚合 2.1 先分组, 再聚合统计 2.2 先分组, 再统 ...

  7. MySQL☞聚合函数/分组函数

    分组函数(聚合函数) 1.count(*/列名): a.*:求出该数据的总条数 select  count(*)  from 表名 b.列名:求出该列中列名不为null的总条数 select  cou ...

  8. mysql按日期分组统计数据

    最近在做一个招聘网时,需要显示一个月内企业招聘信息的发布数量,按日期分组统计,刚开始是直接从源数据库表里面进行group by,但这样子就出现日期不连续的问题了,我想要的效果是,若当天没有数据,则显示 ...

  9. 常用sql:按照表中的某一列对数据进行分组,统计数据条数

    select FROM_UNIXTIME(start_time,'%Y-%m-%d')as date,COUNT(*) FROM random_num GROUP BY FROM_UNIXTIME(s ...

随机推荐

  1. CUDA2.2-原理之存储器访问

    本小节来自<大规模并行处理器编程实战>第四节,该书是很好的从内部原理结构上来讲述了CUDA的,对于理解CUDA很有帮助,借以博客的形式去繁取间,肯定会加入自己个人理解,所以有错误之处还望指 ...

  2. JavaScript学习笔记-简单的计时钟表

    <!DOCTYPE html> <html lang="en" xmlns="http://www.w3.org/1999/xhtml"> ...

  3. 来个linq to js

    说这个话题之前,我们来讲一下C#的linq  语法.在C#里面我们会对列表进行操作,如OrderBy(p=>p.property),Where(p=>p.property==..) 括号里 ...

  4. Java--剑指offer(2)

    6.把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. a)使用ArrayList来存放元素 public class Solution { public static int min ...

  5. android相关技术及岗位

    Android应用开发    Android底层嵌入式    Android架构师 应用开发路线javaSE-->java for Android——>eclipse使用技巧-->A ...

  6. 给Linux装图形化界面

    在工作中遇到这种情况,安装confluence服务的时候需要调用图形化桌面,但是原来装系统的时候是最小化装的,所以这里就麻烦了 给装图形化吧 在我们安装Linux系统时,刚开始的时候可能没有安装图形界 ...

  7. openwrt的环境搭建、定制和编译

    参考1:编译openwrt全过程 参考2: ARM9的OpenWRT系统的移植以及 无线视觉操控系统的软件开发 参考3:搭建OpenWrt开发环境(包括编译过程) 参考4:各个openwrt版本的sv ...

  8. [转]Eclipse中的Web项目自动部署到Tomcat

    原文地址:http://www.cnblogs.com/ywl925/p/3815173.html 原因 很长时间没用Eclipse了,近期由于又要用它做个简单的JSP项目,又要重新学习了,虽然熟悉的 ...

  9. 【转】css布局居中和CSS内容居中区别和对应DIV CSS代码

    原文地址:http://www.divcss5.com/jiqiao/j771.shtml css布局居中和CSS内容居中区别和对应DIV CSS代码教程与图文代码案例篇 对于新手来说DIV CSS布 ...

  10. 【BZOJ 3242】【UOJ #126】【CodeVS 3047】【NOI 2013】快餐店

    http://www.lydsy.com/JudgeOnline/problem.php?id=3242 http://uoj.ac/problem/126 http://codevs.cn/prob ...