Hibernate的关联映射

关联映射分类:

多对一关联映射、一对一关联映射、唯一外键关联、主键关联、一对多关联映射、多对多关联映射

多对一关联映射 - many-to-one:

在“多”方的映射文件中使用<many-to-one>元素来配置多对一关联关系。

<many-to-one
        name="propertyName"                                                      
        column="column_name"                                                    
        class="ClassName"                                                             
        cascade="all|none|save-update|delete"                           
        property-ref="propertyNameFromAssociatedClass"      
        not-null="true|false"                                                            
/>
name:待映射的持久化类的属性名。
column:column用于指定持久化类对应的表的外键字段名。(可选)
(3) class:关联的类的名字。 (可选)
(4) cascade(级联):指明哪些操作会从父对象级联到关联的对象。 (可选)
(5) property-ref:指定关联类的一个属性,这个属性将会和本外键相对应。 如果没有指定,会使用对方关联类的主键。 (可选) 
(6) not-null:使用DDL为外键字段生成一个非空约束。(可选) 

many-to-one的映射最常用,也是最容易理解和编写的
    <many-to-one name="group"  column=“groupid”/>
生成的DDL语句如下
create table T_Group (id varchar(255) not null, name varchar(255), primary key (id))
create table User (id varchar(255) not null, name varchar(255), password varchar(255), createTime datetime, expireTime datetime, groupid varchar(255), primary key (id))
alter table User add index FK285FEBC3D18669 (groupid), add constraint FK285FEBC3D18669 foreign key (groupid) references T_Group (id)

从生成的DDL语句,我们可以知道,实际上是在User表上建立了一个指向Group表的外键关联

重要属性 - cascade(级联)
级联的意思是指定两个对象之间的操作联动关系,对一个主控对象执行了操作之后,对其指定的级联对象也需要执行相同的操作
    总共可以取值为:all、none、save-update、delete
all-代表在所有的情况下都执行级联操作
none-在所有情况下都不执行级联操作,默认
save-update-在保存和更新的时候执行级联操作
delete-在删除的时候执行级联操作
如:<many-to-one name=“group” column=“groupid” cascade=“all”/>

编写实际例子测试many-to-one以及cascade属性的配置

配置文件:

<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

    <session-factory>
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/demo_test?characterEncoding=UTF-8</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">123456</property>

        <!--指定数据库方言 -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
        <!--在控制台显示执行的数据库操作语句 -->
        <property name="hibernate.show_sql">true</property>
        <!--在控制台显示执行的数据库操作语句(格式) -->
        <property name="hibernate.format_sql">true</property>
        <!--hibernate根据实体自动生成数据库表 -->
        <property name="hibernate.hbm2ddl.auto">update</property>

        <!-- 配置 CurrentSession -->
        <property name="hibernate.current_session_context_class">thread</property>

        <!-- 注解配置entity -->
        <mapping class="demo.entity.User" />
        <mapping class="demo.entity.Group" />
        <!-- <mapping class="demo.entity.IdCard" /> -->
    </session-factory>

</hibernate-configuration>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值