首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Hibernate_day03总结

在 Hibernate 提供的各种检索方式中, HQL使用最广的一种检索方式....连接查询) HQL连接查询的时候: * 交叉连接: * 内连接: * 显示内连接:inner join * 隐式内连接:where * 迫切内连接: * 外连接: * 左外连接: * 右外连接: * 迫切左外连接...集合上的fetch和lazy fetch:控制查询其关联对象采用的SQL语句的格式. * select :普通select查询.(默认) * join :使用连接查询....(fetch配置为join那么lazy就会失效.) * subselect :使用子查询查询其关联对象. lazy:控制查询其关联对象是否采用延迟加载 * true :采用延迟加载(默认) * false...上的fetch 和 lazy: fetch:控制SQL的格式 * select :普通select语句(默认) * join :迫切左外连接 lazy:控制关联对象是否采用延迟

1K30

加速你的Hibernate引擎(下)

4.6 HQL调优 4.6.1 索引调优 HQL看起来和SQL很相似。从HQLWHERE子句中通常可以猜到相应的SQL WHERE子句。WHERE子句中的字段决定了数据库将选择的索引。...* 4.6.2绑定参数 vs.字符串拼接 既可以使用绑定参数构造HQLWHERE子句,也可以使用字符串拼接的方法,该决定对性能会有一定影响。...例如,一小数据范围可能只返回数据总量的5%,而一大段数据范围可能返回数据总量的90%。前者使用索引更好,而后者则最好使用全表扫描。...如果将fetch="select"替换成fetch="subselect",pojoB生成的SQL语句就是这样的: select … from pojoB where pojoa_id in(select...以下是原始代码中截取出来的一: Query query = session.createQuery("FROM IsoDeal d WHERE chunk-clause"); query.setLockMode

94630

HQL语句大全

1 Hibernate 中使用SQL HQL不是万能的,无法执行插入语句和非常复杂的查询,Hibernate 也支持SQL查询。...本手册中的HQL关键字将使用小写字母. 很多用户发现使用完全大写的关键字会使查询语句 的可读性更强, 但我们发现,当把查询语句嵌入到Java语句中的时候使用大写关键字比较难看。...注意fetch构造变量在使用了scroll() 或 iterate()函数 的查询中是不能使用的。最后注意,使用full join fetch 与 right join fetch是没有意义的。...如果你使用属性级别的延迟获取(lazy fetching)(这是通过重新编写字节码实现的),可以使用 fetch all properties 来强制Hibernate立即取得那些原本需要延迟加载的属性...from Document fetch all properties order by namefrom Document doc fetch all properties where lower(doc.name

2.5K50

day31_Hibernate学习笔记_03

,在使用集合时,若调用size方法查询数量,则Hibernate会发送count语句,只查询数量,不加载集合内的数据         fetch:决定加载集合使用的sql语句种类             ...   使用子查询语句,在一次加载多个客户的订单数据的情况下才有效         fetch       lazy    结果         ------------------------         ...            select      (默认值)使用普通select加载             join        使用表连接加载数据         fetch       lazy...HQL语法示例: 关键字 说明 select 别名/属性名/表达式 from 实体类名 as 别名 (as可以省略哦) where 过滤条件 group by 分组条件 having 分组后的结果的过滤条件...        session.beginTransaction();         Query query = session.createQuery("from Customer c, Order o where

2.4K40

SSH框架之旅-hibernate(4)

HQL 查询 使用 Query 对象调用相关的方法来做查询,需要写相关的hql语句,这是 hibernate 提供的查询语言,hql 语句中写的是实体类和属性,而 sql 语句中写的是数据表和字段。...查询 ---- 常用的 hql 语句(关键字大小写都可以的): 查询所有: from 实体类名称 条件查询(使用 AS 关键词设置别名): from 实体类名称 as 别名 where 别名....from 实体类名称 as 别名 where 别名.属性名称=? and 别名.属性名称=? from 实体类名称 as 别名 where 别名.属性名称 like ?...select 属性名称 from 实体类名称 6.函数查询: 在HQL中也是可以使用 sql 函数的,count()函数计算数量,sum()函数求和,avg()函数计算平均值,max()函数计算最大值...在 set 标签上使用fetch属性和 lazy 属性。fetch 的默认就是 select 值,如果 fetch 属性的值为 join 那么 lazy 里面的值设置就失效了。

1.6K30

SpringData JPA就是这么简单

value = "select count(1) from employee") public long getCount(); 学过Hibernate的都知道上面的不是原生的SQL语句,是HQL...二、JPQL基础 原来JPQL是JPA的一种查询语言,之前我是认为它和HQL是一样的。其实是两个概念。不过它们用起来还真是差不多。 无非就是:JPA对应JPQL,而Hibernate对应HQL而已。...2.5 小总结 https://www.zhihu.com/question/53706909 引入知乎的一回答: 基本的增删改查和调用存储过程通过Spring Data JPA Repository...Class targetEntity() default void.class; CascadeType[]cascade()default(); FetchType fetch...3,fetch属性是该实体的加载方式,默认为即时加载EAGER 4,optional属性表示关联的该实体是否能够存在null值,默认为ture,如果设置为false,则该实体不能为null, 5,

1.6K80
领券