HQL连接查询和注解
HQL连接查询和注解
一:HQL连接查询
- 各种连接查询:
内连接:inner join或join
From Entity inner [inner] join [fetch] Entity.property;
左外连接:left outer join或left join
From Entity left[outer] join [fetch] Entity.property;
迫切左外连接:left outer join fetch或left join fetch
右外连接:right outer join或right join
迫切连接:inner join fetch或join fetch
注:迫切连接要使用对象连接,不然的话会出错。
等值连接:
From Dept d,Emp p where d=e.dept;
- 聚合函数
select count(*),sum(sal),min(sal),max(sal),avg(sal)from Emp;
List<Object[]>list=query.list();
for (Object[] o:list) {
System.out.println("总:"+o[0]+"和:"+o[1]+"最小值:"+o[2]+"最大值:"+o[3]+"平均数:"+o[4]);
}//省略其它代码
按职位统计员工个数:
select e.job,count(*) from Emp e group by e.job
统计每个部门下的员工个数并且大于2的显示输出:
select e.job,count(*) from Emp e group by e.job having count(*)>2;
- 子查询关键字:
all:子查询返回所有记录。
any:子查询返回的任意的一条记录。
some:与“any”意思相同
in:与“=any意思相同”
exists:子查询语句至少返回一条记录。
- 操作集合函数或属性。
size()或size:获取集合中的元素数目。
minIndex()或minIndex:对于建立索引的集合,获取最小的索引
maxIndex()或maxIndex:对于建立索引的集合,获取最大的索引。
minElement()或minElement:对于包含基本类型的元素集合,获得集合中取值最小的元素。
maxElement()或maxElement: 对于包含基本类型的元素集合,获得集合中取值最大的元素。
Elements();获取集合中的所有元素。
二:查询性能优化
- hibernate查询优化策略:
(1.)使用迫切左外连接,或迫切连接查询策略,配置二级缓存和查询等方式,减少select语句数目,降低访问数据库的频率。
(2.)使用延迟加载等方式避免加载多余不需要访问的数据。
(3.)使用Query接口的iterate()方法减少select语句的字段,降低访问数据库的数据量,并结合缓存等机制减少数据库的访问次数,提高查询效率。
2.HQL优化:
(1.)避免使用or操作的不当。
(2.)避免使用not。
(3.)避免使用like的特殊形式。
(4.)避免使用having子句。
(5.)避免使用distinct。
(6.)索引在以下情况下失效,使用时注意。
对字段使用函数,该字段的索引将不起作用。如:substring(aa,1,2)=’xxx’
对字段进行计算,该字段的索引将不起作用。如:price+10。
三:注解
- 使用hibernate注解的步骤如下:
(1.)使用注解配置持久化类及对象的关联关系。
(2.)在hibernate配置文件(hibernate.cfg.xml)中声明持久化类,语法如下:
<mapping class=”持久化类完整限定名”>
- 配置持久化类的常用注解:
@Entity:将一个类声明为持久化类。
@Table:为持久化映射指定表。
@Id:声明了持久化类的表示属性。
@GeneratedValue:定义表示属性的生成策略。
@UniqueConstraint:定义表的唯一约束。
@Lob:表示属性将被持久化为BLOD或者CLOD类型。
@Column:将属性映射到数据库字段。
@Transient:指定可以忽略的属性,不用持久化到数据库。
HQL连接查询和注解的更多相关文章
- Hibernate批量处理数据、HQL连接查询
一.批量处理操作 批量处理数据是指在一个事务场景中处理大量数据.在应用程序中难以避免进行批量操作,Hibernate提供了以下方式进行批量处理数据: (1)使用HQL进行批量操作 数据库层面 ...
- 【学习笔记】Hibernate HQL连接查询和数据批处理 (Y2-1-7)
HQL连接查询 和SQL查询一样 hql也支持各种链接查询 如内连接 外连接 具体如下 左外连接 left (outer) join 迫切左外连接 left (outer) join fetch 右外 ...
- Hibernate批量处理数据、[HQL连接查询]
一.批量处理操作 批量处理数据是指在一个事务场景中处理大量数据.在应用程序中难以避免进行批量操作,Hibernate提供了以下方式进行批量处理数据: (1)使用HQL进行批量操作 数据库层面 (2)使 ...
- HQL连接查询
HQL提供了连接查询机制如内连接,外连接,,还允许显示指定迫切内连接,和迫切外联结. 连接类型 内连接 inner join 或join 迫切内链接 inner join fetch 左外联结 le ...
- HQL的内连接查询
/** * HQL的内连接查询 * String hql="from Customer c inner join fetch c.linkmans"; */ @Test publi ...
- hibernate-HQL连接查询
和SQL查询一样,HQL也支持各种各样的连接查询, 如内连接.外连接. 实例: package Test; import static org.junit.Assert.*; import java. ...
- hibernate 实现多表连接查询(转载)
http://www.cnblogs.com/lihuiyy/archive/2013/03/28/2987531.html 为了方便,直接粘过来,方便查看.不收藏了 Hibernate主要支持两种查 ...
- hql 关联查询
HQL 带的连接语句只能是实体与 该实体的属性 进行连接 其意义就是为了优化(通过延迟加载查询关联的属性)需要进行配置 from A left join A.B where (b.flag is nu ...
- 一步步学习NHibernate(9)——连接查询和子查询(1)
请注明转载地址:http://www.cnblogs.com/arhat 在前几章中,我们把HQL的基本查询学习了一下,但是只有基本查询很显然不能满足我们的需求,那么就需要一下复杂查询比如" ...
随机推荐
- 配置zabbix agent向多个server发送数据
1.背景: agent 端:dba-test-hzj02 172.16.59.197 server端:172.16.59.197 ,172.16.59.98 2.方式: 配置多个server,se ...
- 执行manage.py syncdb提示Unknown command: 'syncdb'
1. 实验环境 ubuntu14.4 + django1.9.7 2. 问题描述 在配置完数据库mysite/settings.py后,通常需要运行 python manage.py syncdb 为 ...
- javascript字典数据结构Dictionary实现
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat=&qu ...
- Android使用RxJava+Retrofit2+Okhttp+MVP练习的APP
Android使用RxJava+Retrofit2+Okhttp+MVP练习的APP 项目截图 这是我的目录结构 五步使用RxJava+Retrofit2+Okhttp+RxCache 第一步 ...
- php 连接mysql数据库以及增删改查
php 连接数据库 一般是用面向对象的方法,需要先创建一个对象,即造一个连接对象,然后再写sql语句,(增改查删),最后执行sql语句 其中在创建连接对象时 我们用到的是MySQLI 是不区分大小写 ...
- 吾八哥学Python(一):搭建Python开发环境(Windows)
学习Python的第一步当然是要配置一下开发环境了,这里记录一下本人在windows 10(64位)下配置Python开发环境的过程,供跟我一样的新手参考一下. 一.下载Python安装包 目前最新的 ...
- 《Unity3D/2D游戏开发从0到1(第二版本)》 书稿完结总结
前几天,个人著作<Unity3D/2D游戏开发从0到1(第二版)>经过七八个月的技术准备以及近3个月的日夜编写,在十一长假后终于完稿.今天抽出一点时间来,给广大热心小伙伴们汇报一下书籍概况 ...
- ThreadPoolExecutor系列<一、ThreadPoolExecutor 机制>
本文系作者原创,转载请注明出处:http://www.cnblogs.com/further-further-further/p/7681529.html 解决问题: 1. 处理大量异步任务时能减少每 ...
- (转)Nginx与tomcat组合的简单使用
原文出自:http://www.cnblogs.com/naaoveGIS/ 1.背景 项目中瓦片资源越来越多,如果提高瓦片的访问效率是一个需要解决的问题.这里,我们考虑使用Nginx来代理静态资源进 ...
- jQuery+Ajax+PHP实现异步分页数据显示
这几天做毕业设计的时候需要使用到一个异步分页的功能,即翻页的时候只是刷新分页的数据而不是刷新整个页面.因为之前做项目的时候没有做过这方面的功能,所以还是纠结了挺长时间的,在网上也找了很多资料,结合自己 ...