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失效,不延迟加载

猜你喜欢

转载自blog.csdn.net/java_raylu/article/details/74035437