hibernate-聚合函数分组统计数据查询
聚合函数:
实例:
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-聚合函数分组统计数据查询的更多相关文章
- 18 12 06 sql 的 基本语句 查询 条件查询 逻辑运算符 模糊查询 范围查询 排序 聚合函数 分组 分页 连接查询 自关联 子查询
-- 数据的准备 -- 创建一个数据库 create database python_test charset=utf8; -- 使用一个数据库 use python_test; -- 显示使用的当前 ...
- Django orm进阶查询(聚合、分组、F查询、Q查询)、常见字段、查询优化及事务操作
Django orm进阶查询(聚合.分组.F查询.Q查询).常见字段.查询优化及事务操作 聚合查询 记住用到关键字aggregate然后还有几个常用的聚合函数就好了 from django.db.mo ...
- hibernate学习系列-----(5)hibernate基本查询下篇:hibernate聚合函数、分组查询及命名查询
在上一篇中,大致学习了hibernate的基本查询:HQL基本查询,今天,继续昨天的步伐,继续学习hibernate的基本查询..... 1.hql聚合函数,先大致列一下hql的聚合函数有哪些吧: 在 ...
- sql server 分组统计数据
说明:group by是sql中对数据表中的数据进行分组的,在select列表中出现的字段必须全部出现在group by 字段中,出现在聚合函数中的字段在group by中可有可无,没有出现在sele ...
- java:Oracle(聚合函数,多表查询,表之间的关系)
1.聚合函数 --max,min,sum,avg,count,nvl(,) -- max:最大值 -- max既能取数字的最大值,也可以取字符串的最大值(英文字母排列顺序),根据场景实际意义来看,最好 ...
- ES 24 - 如何通过Elasticsearch进行聚合检索 (分组统计)
目录 1 普通聚合分析 1.1 直接聚合统计 1.2 先检索, 再聚合 1.3 扩展: fielddata和keyword的聚合比较 2 嵌套聚合 2.1 先分组, 再聚合统计 2.2 先分组, 再统 ...
- MySQL☞聚合函数/分组函数
分组函数(聚合函数) 1.count(*/列名): a.*:求出该数据的总条数 select count(*) from 表名 b.列名:求出该列中列名不为null的总条数 select cou ...
- mysql按日期分组统计数据
最近在做一个招聘网时,需要显示一个月内企业招聘信息的发布数量,按日期分组统计,刚开始是直接从源数据库表里面进行group by,但这样子就出现日期不连续的问题了,我想要的效果是,若当天没有数据,则显示 ...
- 常用sql:按照表中的某一列对数据进行分组,统计数据条数
select FROM_UNIXTIME(start_time,'%Y-%m-%d')as date,COUNT(*) FROM random_num GROUP BY FROM_UNIXTIME(s ...
随机推荐
- C#发展历程以及C#6.0新特性
一.C#发展历程 下图是自己整理列出了C#每次重要更新的时间及增加的新特性,对于了解C#这些年的发展历程,对C#的认识更加全面,是有帮助的. 二.C#6.0新特性 1.字符串插值 (String In ...
- HTTP 错误 500.24 - Internal Server Error的解决方法
错误提示: 最可能的原因: system.web/identity@impersonate 设置为 true. 解决办法: 现在经典模式 连微软都几乎放弃了 原设想是为iis不断升级 提供的一种兼 ...
- Android开发之SlidingMenu开源项目的使用和问题
一.关于如何导入lib 第一步:New Module 点击+: 第二步:选择Import Eclipse ADT Project: 第三步:选择你想引入的lib文件,选择完成后,会开始编译你添加的项 ...
- golang: 把sql结果集以json格式输出
func getJSON(sqlString string) (string, error) { stmt, err := db.Prepare(sqlString) if err != nil { ...
- 25 uname-用于显示系统信息
uname可显示电脑以及操作系统的相关信息. 语法 uname [-amnrsv][--help][--version] 参数说明: -a或--all 显示全部的信息. -m或--machine 显示 ...
- C++11异常处理 noexcept
1.简介 在C语言中,如果程序的运行出现异常.错误,我们想提供方案处理这些异常时,我们面临许多问题,如: (1)C语言没有提供统一(标准)的方式来处理错误: (2)无法保证错误会被正确的处理: (3) ...
- applicationContext.xml和dispatcher-servlet.xml的区别
在SpringMVC项目中我们一般会引入applicationContext.xml和dispatcher-servlet.xml两个配置文件,这两个配置文件具体的区别是什么呢? Spring 官方文 ...
- 【BZOJ 1875】【SDOI 2009】HH去散步
水啊水,最后ans别忘了%哦! #include<cstdio> #include<cstring> #include<algorithm> using names ...
- Region的周长, 面积与紧凑程度
Perimeter 边界长度. 计算方式跟边界的表示方式有关 Area 包含的点的个数 Compactness 两种常用的计算方式 \(\frac {perimeter^2}{area}\). cir ...
- 强连通 HDU 3861
t个样例 n个点m条边 分成一些区 2个点互相能到达必须分在一个区 一个区中任何2个点可以u->v 或者v->u 任何点都要有自己的区 求最小的区的数目 强联通缩点 成新图 二分匹配 求最 ...