hibernate检索策略

Hibernate 提供了 3 种检索策略: <o:p></o:p>

l        延迟检索; <o:p></o:p>

l        立即检索; <o:p></o:p>

l        迫切左外连接; <o:p></o:p>

Hibernate 提供 2 种方式来确定检索策略,一中是在配置文件当中,另外一种是在程序种设置。当然,如果你在程序中设置了检索策略,那么你在配置文件中的设置也就无效了。另外的一种情况是 HQL 会忽略配置文件的设置,而总是采用迫切左外连接。 <o:p></o:p>

一、 类级别的检索 <o:p></o:p>

可以选择的检索策略是立即检索和延迟检索,默认的是立即检索。用配置文件中的 <class> 节点的 lazy 来控制。 <o:p></o:p>

注意:不管你在配置 class lazy true 还是 false ,对load()、find()、 get() create Criteria () 方法都不起作用,只有对 load() 方法起作用。 <o:p></o:p>

当你使用的检索策略是 lazy 的时候,当你执行 <o:p></o:p>

Customer customer = (Customer)session.load(Customer.class,new Long(1));<o:p></o:p> 的时候, Hibernate 不从数据库检索数据,而只是产生一个代理类,当应用程序第一次访问Customer代理类实例时(例如,调用customer.get***()方法),此时会初始化代理类实例,在初始化过程中执行select语句,及只有当你执行 Customer.getName();<o:p></o:p> 的时候, Hibernate 才到数据库取数据。所以,如下的代码是会被抛出异常的:

Session session  =  sessionFactory.openSession();
transaction tx 
=   null ;
tx 
=  session.beginTransaction();
  Customer customer 
=  (Customer)session.load(Customer. class , new  Long( 1 ));
tx.commit();
  session.close();
customer.getName();
<o:p>

get() 方法总是用的立即检索,如果和它相关联的类也是用的立即检索,那么也会把相关联的数据也检索出来。

<o:p></o:p> 

二、 一对和多对多关联检索 <o:p></o:p>

一般地,为了有减少对数据库的访问,我们往往用延迟检索的策略。所以,我们优先使用如下方式; <o:p></o:p>

<set class=”order” inverse=”true’ lazy=”true” ><o:p></o:p>

但是,我们在检索“多”的一方的时候, Hibernate 不能为我们产生代理类。由此,我们就要用 betch-size 的配置来减少 SQL 语句。当我们使用 outer-join 属性的时候,我们就没有必要使用 lazy 属性了。 Outer-join 会一次将“一”方和与之相关的“多”方用左外连接的方式检索出来。 <o:p></o:p>

Session session = sessionFactory.openSession();<o:p></o:p>

                     Transaction tx = null;<o:p></o:p>

                     tx = session.beginTransaction();<o:p></o:p>

                    Customer customer = (Customer)session.get(Customer.class,new Long(1));

此时执行以下SQL语句:select * from CUSTOMERS left outer join ORDERS on CUSTOMERS.ID=ORDERS.CUSTOMER_ID where CUSTOMERS.ID=1;

注意:Session的find()方法会忽略映射文件中配置的迫切左外连接检索策略。即使设置了outer-join为true,仍然采用立即检索策略。其他如get()、load()方法都会受到影响。

 

<Customer.hbm.xml>文件中,如果<set name="orders" inverse="true" outer-join="true">,则当检索Customer对象时,会采用迫切左外连接策略来检索所有关联的Order对象。

 

<Order.hbm.xml>文件中,如果<many-to-one name="customer" column="CUSTOMER_ID" class="mypack.Customer" outer-join="true">,则当检索Order对象时,会采用迫切左外连接策略来检索所有关联的Customer对象。

</o:p>

你可能感兴趣的:(sql,xml,Hibernate)