gpt4 book ai didi

java - 如何让 Hibernate 在 WebLogic 10g 上对每个父/子关系执行不超过一个 SQL 查询?

转载 作者:行者123 更新时间:2023-11-30 11:51:02 25 4
gpt4 key购买 nike

我们需要取回一个 Widget 集合,其中每个 widget 可以包含零个或多个 Fidget。我们的问题是,每当我们从 Widget 运行 时,Hibernate 都会为每个 Widget 上的每个 Fidget 生成一个 SQL 查询。因此,如果我有一个包含 19 个 Fidget 的 Widget,Hibernate 将运行 20 个 SQL 查询!我原以为只有两个查询:一个针对 Widget,一个针对 Fidget。

我们有 SQL Server 2005 和 WebLogic 10g。

我的相关 Spring 配置:

<jee:jndi-lookup id="dataSourceA" jndi-name="jdbc/dataSourceA" />
<bean id="sessionFactoryA" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSourceA" />
<property name="mappingResources">
<list>
<value>com/mycompany/database/Widget.hbm.xml</value>
<value>com/mycompany/database/Fidget.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<value>
hibernate.query.factory_class=org.hibernate.hql.classic.ClassicQueryTranslatorFactory
hibernate.dialect=org.hibernate.dialect.SQLServerDialect
hibernate.show_sql=true
</value>
</property>
</bean>
<bean id="transactionManagerA" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactoryA" />
</bean>

我的 Widget.hbm.xml:

<class name="Widget" package="com.mycompany.database">
<id name="id" column="ID" type="integer">
<generator class="identity" />
</id>
...
<set name="fidgets" table="Fidget" lazy="false">
<key column="WidgetID" />
<one-to-many class="Fidget" />
</set>
</class>

我的 Fidget.hbm.xml:

<class name="Fidget" package="com.mycompany.database">
<id name="id" column="ID" type="integer">
<generator class="identity" />
</id>
...
<many-to-one name="widget" column="WidgetID" class="Widget" lazy="false" />
</class>

下面的 SQL 是由 Hibernate 为一个有四个 Fidget 的 Widget 和一个有六个 Fidget 的 Widget 生成的:

select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 7
select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 7
select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 7
select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 7
select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 8
select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 8
select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 8
select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 8
select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 8
select fidget_.Col1, fidget_.Col2, ... from Fidget fidget_ where fidget_.WidgetID = 8

最佳答案

启用batch fetching在 Hibernate 配置中减少查询数量,或执行将加载 Widget 及其 Fidget 的查询:

select w from Widget w left join fetch w.fidgets where ...

这在 reference documentation 中也有详细描述,这是一个很好的信息来源。

关于java - 如何让 Hibernate 在 WebLogic 10g 上对每个父/子关系执行不超过一个 SQL 查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7666676/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com