hibernate相关总结

本文解析了Hibernate框架中的关联关系配置,包括多对多关联的inverse属性使用、many-to-one中的insert及update属性作用以及cascade级联操作的不同选项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 1.hibernate关联关系总结:

查看"hibernate 多对多影射 .rar"文件中的内容.

 

 

 

一个Person可以参加多个Event,一个Event有多个Person参加。
映射文件如下:

<!-- Person.hbm.xml -->
<
hibernate-mapping  package ="events" >
  
< class  name ="Person"  table ="person" >
      
< id  name ="id"  column ="person_id" >
          
< generator  class ="native" />
      
</ id >
      
< property  name ="age"  length ="0" />
      
< property  name ="firstname" />
      
< property  name ="lastname" />
      
< set  name ="events"  table ="person_event" >
          
< key  column ="person_id" />
          
< many-to-many  column ="event_id"  class ="events.Event" />
      
</ set >
  
</ class >
</ hibernate-mapping >


 

<!-- Event.hbm.xml -->
<
hibernate-mapping >
  
< class  name ="events.Event"  table ="events" >
      
< id  name ="id"  column ="event_id" >
            
< generator  class ="native" />
      
</ id >
      
< property  name ="date"  column ="events_date"  type ="timestamp" />
      
< property  name ="title"  column ="events_title" />
      
< set  name ="participants"  table ="person_event"  inverse ="true" >
          
< key  column ="event_id" />
          
< many-to-many  column ="person_id"  class ="events.Person" />
      
</ set >
  
</ class >
</ hibernate-mapping >


inverse=true的含义: 由双向关联另一方维护该关联,己方不维护该关联(只能进行查询操作)。在上述代码中,由Person方维护该<many-to-many>关系,示例代码如下(以向Person参与的Event中加入新的Event为例):

        Session session  =  HibernateUtil.getSessionFactory().getCurrentSession();
        session.beginTransaction();
        Person p 
=  (Person) session.load(Person. class , personId);
        Event e 
=  (Event) session.load(Event. class , eventId);
        p.getEvents().add(e);//执行该代码时,hibernate会向中间表 person_event中插入person_id和event_id记录,如果换成e.getParticipants().add(p)的话,该代码将不会被执行,即hibernate不会向表person_event中插入记录。
        session.getTransaction().commit();


要注意的一点:在双向关联的关系中,映射的column(和table)的值要一致(即要用相同的表名和列名),不然设置为inverse="true"的这方将失去这个双向关系,而变成了一个单向关联。

 

 

3.many-to-one中的insert="false"   update="false"解释:

insert="false"   update="false"  是讲生成sql语句的时候,是不是对该属性进行操作   
 假如,在name属性上设置了insert="false",而没有设置update="false",则,则生成的插入语句中没有该属性,但更新语句上有,因为默认是true的

 

4.cascade的解释:

cascade
有五个选项

分别是: all ,delete ,none,save-update,delete-orphan ;
        
all : 所有情况下均进行关联操作。

        none
:所有情况下均不进行关联操作。这是默认值
        save-update:
在执行save/update/saveOrUpdate时进行关联操作。
        delete
:在执行delete时进行关联操作。
        delete-orphan:
save/update/saveOrUpdate时,相当于save-update ;当删除操作时,相当于delete

all的意思是save-update + delete
all-delete-orphan
的意思是当对象图中产生孤儿节点时,在数据库中删除该节点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值