Hibernate5-唯一查询和聚合查询

1.创建项目,项目名称hibernatedemo8,目录结构如图所示

2.在项目中创建lib目录存储jar文件,目录结构如图所示

3.在src目录中创建实体Bean Forum,包名(com.mycompany.demo.bean),如图所示

4.实体Bean Forum的内容如下

package com.mycompany.demo.bean;

public class Forum {
	private int fid;
	private String name;

	public Forum() {
		super();
	}
	public Forum(String name) {
		super();
		this.name = name;
	}
	public int getFid() {
		return fid;
	}
	public void setFid(int fid) {
		this.fid = fid;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + fid;
		result = prime * result + ((name == null) ? 0 : name.hashCode());
		return result;
	}
	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		Forum other = (Forum) obj;
		if (fid != other.fid)
			return false;
		if (name == null) {
			if (other.name != null)
				return false;
		} else if (!name.equals(other.name))
			return false;
		return true;
	}
}

5.在src目录中创建实体Bean Forum的映射文件Forum.hbm.xml,包名(com.mycompany.demo.bean),如图所示

6.映射文件Forum.hbm.xml的内容如下

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
 "-//Hibernate/Hibernate Mapping DTD//EN"
 "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 

<!--
	package:指定<class/>所在的包 
 -->
<hibernate-mapping package="com.mycompany.demo.bean">
	<!--
		name:类名
		table:表名 
		catalog:数据库名称,默认为hibernate.cfg.xml中配置的数据库名称
	 -->
   <class name="Forum" table="hnsq_forum" catalog="b_shequ_two">
      <meta attribute="class-description">
         This class contains the forum detail. 
      </meta>
      <!--
      	name:属性名
      	colum:列名 
       -->
      <id name="fid" type="int" column="fid">
      		<!--
      			increment:hibernate维护主键值
      			identity:数据库自增长
      			sequence:序列
      			native:根据不同的数据库选择生成策略
      			uuid:通过UUID算法生成,实际使用较多
      			assigned:手工设置
      		 -->
         <generator class="native"/>
      </id>
      
      <!--
      	length:字节长度
      	type:字段类型,支持java和hibernate类型
      	not-null:非空约束
      	unique:唯一性约束
       -->
      <property name="name" column="name" type="string" length="50" not-null="true" unique="false"/>
   </class>
</hibernate-mapping>

7.在src目录中创建工具类 HbnUtil,包名(com.mycompany.demo.util),如图所示

8.工具类 HbnUtil的内容如下

package com.mycompany.demo.util;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HbnUtil {
	private static SessionFactory sessionFactory;

	public static Session getSession(){
		if(sessionFactory == null || sessionFactory.isClosed()){
			sessionFactory = new Configuration().configure().buildSessionFactory();
		}

		return sessionFactory.getCurrentSession();
	}
}

9.在src目录中创建Hibernate的配置文件hibernate.cfg.xml,如图所示

10.Hibernate的配置文件hibernate.cfg.xml的内容如下

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-configuration SYSTEM 
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
   <session-factory>
   	<!-- 方言,可以从Hibernate核心jar(hibernate-core-x.x.x.Finall.jar)
   	文件中的or.hibernate.dialect包中找到相应的类,类的全名就是 -->
	   <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
	   <!-- 驱动 -->
	   <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>

	   <!-- 数据库连接地址 -->
	   <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/b_shequ_two</property>
	   <!-- 用户名 -->
	   <property name="hibernate.connection.username">
	      root
	   </property>
	   <!-- 密码 -->
	   <property name="hibernate.connection.password"></property>
	   <!--
	   		create:每次都新创建,如果存在就删除
	   		create-drop:创建新表,sessionFactory关闭,表会删除
	   		update :表字段增加,会同步,字段减少不同步,数据改变会同步修改
	    -->
	   <property name="hibernate.hbm2ddl.auto">update</property>
	   <!-- 输出sql -->
	   <property name="hibernate.show_sql">true</property>
	   <!-- 格式化sql -->
	   <property name="hibernate.format_sql">true</property>
	   <!-- 事务环境一个线程对一个事务
	   		thread:本地事务环境
	   		jta:分布式事务环境
	   		SpringSessionContext:用于ssh整合
	    -->
	   <property name="hibernate.current_session_context_class">thread</property>	  
	   
	   <!-- 使用c3p0数据源 -->
	   <property name="hibernate.connection.provider_class">
	       org.hibernate.c3p0.internal.C3P0ConnectionProvider
	   </property> 

	   <!-- List of XML mapping files -->
	   <mapping resource="com/mycompany/demo/bean/Forum.hbm.xml"/>
</session-factory>
</hibernate-configuration>

11.在项目中创建test目录存储测试文件,文件名称ManageForum,包名(com.mycompany.demo.bean),目录结构如图所示

12.ManageForum测试类的内容如下

package com.mycompany.demo.bean;

import java.math.BigInteger;
import java.util.List;

import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Projections;
import org.hibernate.criterion.Restrictions;
import org.junit.Before;
import org.junit.Test;

import com.mycompany.demo.util.HbnUtil;

public class ManageForum {

	private Session session;

	@Before
	public void init(){
		session = HbnUtil.getSession();
	}

	/*
	 * 唯一性查询-SQL
	 */
	@Test
	public void testUniqueSQL(){
		try {
			session.beginTransaction();
			String sql = "SELECT * FROM hnsq_forum WHERE fid = ?";
			Forum forum = (Forum) session.createSQLQuery(sql)
					.addEntity(Forum.class)
					.setInteger(0, 54)
					.uniqueResult();
			System.out.println(forum.getName());
			session.getTransaction().commit();
		} catch (Exception e) {
			session.getTransaction().rollback();
			e.printStackTrace();
		}
	}

	/*
	 * 唯一性查询-HQL
	 */
	@Test
	public void testUniqueHQL(){
		try {
			session.beginTransaction();
			String sql = "FROM Forum WHERE fid = ?";
			Forum forum = (Forum) session.createQuery(sql)
					.setInteger(0, 54)
					.uniqueResult();
			System.out.println(forum.getName());
			session.getTransaction().commit();
		} catch (Exception e) {
			session.getTransaction().rollback();
			e.printStackTrace();
		}
	}

	/*
	 * 唯一性查询-QBC
	 */
	@Test
	public void testUniqueQBC(){
		try {
			session.beginTransaction();
			Forum forum = (Forum) session.createCriteria(Forum.class)
					.add(Restrictions.eq("fid", 54))
					.uniqueResult();
			System.out.println(forum.getName());
			session.getTransaction().commit();
		} catch (Exception e) {
			session.getTransaction().rollback();
			e.printStackTrace();
		}
	}

	/*
	 * 聚合函数查询-SQL
	 */
	@Test
	public void testCountSQL(){
		try {
			session.beginTransaction();
			String sql = "SELECT COUNT(*) FROM hnsq_forum";
			BigInteger total = (BigInteger) session.createSQLQuery(sql).uniqueResult();
			System.out.println(total);
			session.getTransaction().commit();
		} catch (Exception e) {
			session.getTransaction().rollback();
			e.printStackTrace();
		}
	}

	/*
	 * 聚合函数查询-HQL
	 */
	@Test
	public void testCountHQL(){
		try {
			session.beginTransaction();
			String sql = "SELECT COUNT(*) FROM Forum";
			Long total = (Long) session.createQuery(sql).uniqueResult();
			System.out.println(total);
			session.getTransaction().commit();
		} catch (Exception e) {
			session.getTransaction().rollback();
			e.printStackTrace();
		}
	}

	/*
	 * 聚合函数查询-QBC
	 */
	@Test
	public void testCountQBC(){
		try {
			session.beginTransaction();
			String sql = "SELECT COUNT(*) FROM Forum";
			Long total = (Long) session.createCriteria(Forum.class)
					.setProjection(Projections.count("fid"))
					.uniqueResult();
			System.out.println(total);
			session.getTransaction().commit();
		} catch (Exception e) {
			session.getTransaction().rollback();
			e.printStackTrace();
		}
	}
}

时间: 2024-11-16 21:43:42

Hibernate5-唯一查询和聚合查询的相关文章

python 之 Django框架(orm单表查询、orm多表查询、聚合查询、分组查询、F查询、 Q查询、事务、Django ORM执行原生SQL)

12.329 orm单表查询 import os if __name__ == '__main__': # 指定当前py脚本需要加载的Django项目配置信息 os.environ.setdefault("DJANGO_SETTINGS_MODULE", "orm_demo.settings") import django django.setup() # 启动Django项目 from app01 import models #返回QuerySet对象的方法: r

MongoDB分组查询,聚合查询,以及复杂查询

准备数据 from pymongo import MongoClient import datetime client=MongoClient('mongodb://localhost:27017') table=client['db1']['emp'] l=[ ('张飞','male',18,'20170301','',7300.33,401,1), #以下是教学部 ('张云','male',78,'20150302','teacher',1000000.31,401,1), ('刘备','m

MySQL查询之聚合查询

为了快速得到统计数据,提供了5个聚合函数: 1. count(*)表示计算总行数,括号中写星与列名,结果是相同的 查询学生总数 select count(*) from students; 2. max(列)表示求此列的最大值 查询女生的编号最大值 select max(id) from students where gender=0; 3. min(列)表示求此列的最小值 查询未删除的学生最小编号 select min(id) from students where isdelete=0; 4

第64篇 自关联 分组查询和聚合查询 Q查询 F查询 ORM进阶

1. 删除'alex'所带班级的 的全部学生 2. 自关联 3. 多对多的自关联 symmetric 4. 一对多 多对多  多的那一边含有的方法 create() add()    set() remove() clear() 原文地址:https://www.cnblogs.com/cavalier-chen/p/9936476.html

django数据查询之聚合查询和分组查询

1.# 获取各区域的总数 # 获取各区域的总数 allnum = OperationTask.objects.filter(task_create_time__range=[starttime, stoptime]).values( 'task_area').annotate(c=Count('id')).values('task_area', 'c').order_by('-c')[:10] 原文地址:https://www.cnblogs.com/CGCong/p/11044256.html

SQL语句汇总(三)——聚合函数、分组、子查询及组合查询 - Darly

–COUNT:统计行数量 –SUM:获取单个列的合计值 –AVG:计算某个列的平均值 –MAX:计算列的最大值 –MIN:计算列的最小值 首先,创建数据表如下: 执行列.行计数(count): 标准格式 SELECT COUNT(<计数规范>) FROM <表名> 其中,计数规范包括: - * :计数所有选择的行,包括NULL值: - ALL 列名:计数指定列的所有非空值行,如果不写,默认为ALL: - DISTINCT 列名:计数指定列的唯一非空值行. 例,计算班里共有多少学生:

[Elasticsearch] 过滤查询以及聚合(Filtering Queries and Aggregations)

本章翻译自Elasticsearch官方指南的Filtering Queries and Aggregations一章. 过滤查询以及聚合 A natural extension to aggregation scoping is filtering. Because the aggregation operates in the context of the query scope, any filter applied to the query will also apply to the

Django学习【第7篇】:Django之ORM跨表操作(聚合查询,分组查询,F和Q查询等)

django之跨表查询及添加记录 一:创建表 书籍模型: 书籍有书名和出版日期,一本书可能会有多个作者,一个作者也可以写多本书,所以作者和书籍的关系就是多对多的关联关系(many-to-many);     一本书只应该由一个出版商出版,所以出版商和书籍是一对多关联关系(one-to-many). 创建一对一的关系:OneToOne("要绑定关系的表名") 创建一对多的关系:ForeignKey("要绑定关系的表名") 创建多对多的关系:ManyToMany(&qu

Django之ORM跨表操作(聚合查询,分组查询,F和Q查询等)

一:创建表 书籍模型: 书籍有书名和出版日期,一本书可能会有多个作者,一个作者也可以写多本书,所以作者和书籍的关系就是多对多的关联关系(many-to-many);     一本书只应该由一个出版商出版,所以出版商和书籍是一对多关联关系(one-to-many). 创建一对一的关系:OneToOne("要绑定关系的表名") 创建一对多的关系:ForeignKey("要绑定关系的表名") 创建多对多的关系:ManyToMany("要绑定关系的表名"