Hibernate延迟加载(查询优化),关联级别延迟加载优化策略

1. 类级别延迟加载:

类级别使用延时加载,可以在class标签上修改是否使用延迟加载

<class name="com.ssh.domain.Customer" table="cst_customer">

2 关联级别延迟加载:默认使用到的时候才进行查询()

默认使用延迟加载,如果不想使用则需要在属性上加上lazy="false":

<set name="Linkmans" cascade="save-update" lazy="false">
		<many-to-one name="customer" column="lkm_cust_id" class="com.ssh.domain.Customer" cascade="save-update" lazy="false">


关联级别优化策略

lazy: 决定是否使用延迟加载,默认值true

fetch: 决定SQL语句格式,默认值select

fetch与lazy搭配使用(一对多,多方set标签上配置):

fetch="join" lazy="false"  //当fetch值为join时,表示迫切左外连接多表查询,此时lazy配置失效,即非延迟加载

fetch="select" 此时属于默认配置,lazy可正常发挥作用

fetch="subselect"  lazy="true"子查询的方式,减少SQL语句,减少查询次数


<many-to-one>上配置策略:

fetch="select" lazy="false" 不延迟加载,多条SQL语句一起执行

fetch="select" lazy="proxy" 是否延迟加载取决于: proxy由一对多中的一方class标签lazy策略决定(类级别)

fetch="join"表示迫切左连接,此时lazy失效,不延迟加载

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值