hibernate一对一的两种情况

ORM
hibernate的原理
hibernate的update
hibernate的delete
hibernate的查询(id的查询)
hibernate的关系映射

 

Hibernate中一对一关系(从表中的主键既是主键也是外键)
让两个实体的主键一样这样就不用加入多余的字段
主表
<class name="com.bjpowernode.hibernate.IdCard" table="t_idCard">
    <id name="id">
    <generator class="sequence">
    <param name="sequnece">carid</param>
    </generator>
    </id>
    <property name="cardNo" ></property>
    <!--维护的是可以在查询主表的时候可以查询到从表中的数据。get或load时候发的sql语句是连接查询语句(无论查询主表还是从表) -->
    <one-to-one name="person"></one-to-one>
</class>


从表
<class name="com.bjpowernode.hibernate.Person" table="t_person">
  <id name="id">
  <generator class="foreign">
  <!--通过idCard找到主表中id  -->
  <param name="property">idCard</param>
  </generator>
  </id>
  <property name="name"></property>
  <!--constrained是告诉从表中的主键既是主键也是外键-->
  <!--发的sql语句是1.查询的是主表中的数据发的就是连接查询2.查询的是从表中的数据发的就是一条数据-->
  <one-to-one name="idCard" constrained="true"></one-to-one>
</class>


  one-to-one指示hibernate如何加载其关联对象,默认根据主键加载
  也就是拿到关系字段值,根据对端的主键来加载关联对象
 
  constrained="true表示,当前主键(person的主键)还是一个外键
  参照了对端的主键(IdCard的主键),也就是会生成外键约束语句

 

Hibernate中一对一关系(从表中的外键唯一){多对一的一种表现}
从表

<class name="com.bjpowernode.hibernate.Person" table="t_person">
  <id name="id">
  <generator class="sequence">
  <!--通过idCard找到id  -->
  <param name="sequence">usid</param>
  </generator>
  </id>
  <property name="name"></property>
  <many-to-one name="idCard" cascade="save-update" unique="true"></many-to-one>
</class>
主表

<class name="com.bjpowernode.hibernate.IdCard" table="t_idCard">
  <id name="id">
    <generator class="sequence">
    <param name="sequnece">carid</param>
    </generator>
  </id>
  <property name="cardNo"  ></property>
  <!--标签中的property-ref属性为关系字段的名称为了可以通过外键查到从表中的数据(维护这种关系的是idCarid)-->
  <one-to-one name="person"  property-ref="idCard"/>
 </class>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值