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的基本查询学习了一下,但是只有基本查询很显然不能满足我们的需求,那么就需要一下复杂查询比如" ...
随机推荐
- ASP.NET Core 2.0 支付宝当面付之扫码支付
前言 自从微软更换了CEO以后,微软的战略方向有了相当大的变化,不再是那么封闭,开源了许多东西,拥抱开源社区,.NET实现跨平台,收购xamarin并免费提供给开发者等等.我本人是很喜欢.net的,并 ...
- 详细分析apache httpd反向代理的用法
html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...
- FPGA在其他领域的应用(四)
工业领域: 从工厂和过程自动化到能源基础设施和机器视觉系统,工业产品有助于改善我们的世界.产品必须安全.可靠.适应性强,而且耐用.同时,商业成功要求你在激烈竞争的市场中行动迅速,同时降低总成本. 英特 ...
- 【学习】滚动延迟加载插件scrollLoading用法
今天遇到一个很好用的滚动延迟加载的插件,作者是我的偶象大神张鑫旭,其博客为http://www.zhangxinxu.com/. 以前也写过这种效果,用的是lazyload,不过只能实现图片的加载.而 ...
- Extjs6(四)——侧边栏导航根据路由跳转页面
本文基于ext-6.0.0 之前做的时候这个侧边栏导航是通过tab切换来切换页面的,但是总感觉不太对劲,现在终于发现怎么通过路由跳转了,分享给大家,可能有些不完善的地方,望大家读后可以给些指点.欢迎留 ...
- Java 线程基本知识
线程 线程和进程 进程 : 进程指正在运行的程序.确切的来说,当一个程序进入内存运行,即变成一个进程,进程是处于运行过程中的程序,并且具有一定独立功能. 线程 : 线程是进程中的一个执行单元(执行路径 ...
- mysql密码更改
1.用户修改密码: 方法一:mysqladmin -u用户 -p密码 password '新密码' mysqladmin -uroot -pdefault password 'zhouli.cn' 方 ...
- ES6 class的继承使用细节
ES6 class的继承与java的继承大同小异,如果学过java的话应该很容易理解,都是通过extends关键字继承. class Animal{ constructor(color){ this. ...
- (转)Spark性能优化:资源调优篇
在开发完Spark作业之后,就该为作业配置合适的资源了.Spark的资源参数,基本都可以在spark-submit命令中作为参数设置.很多Spark初学者,通常不知道该设置哪些必要的参数,以及如何 ...
- 【转】java事件监听机制
java中的事件机制的参与者有3种角色: 1.event object:事件状态对象,用于listener的相应的方法之中作为参数,一般存在与listerner的方法之中 2.event source ...