hibernate one-to-many/many-to-one 使用中间表/使用join 标签

<class name="Person">
  <id name="id" column="personId">
       <generator class="native" />
  </id>
  <set name="addresses" table="PersonAddress">
       <key column="personId" />
       <many-to-many column="addressId" unique="true" class="Address" />
  </set>
 </class>
 <class name="Address">
       <id name="id" column="addressId">
       <generator class="native" />
  </id>
  <join table="PersonAddress" inverse="true" optional="true">
        <key column="addressId" />
        <many-to-one name="person" column="personId" not-null="true" />
  </join>
 </class>

DDL:

create table Person ( personId bigint not null primary key )
create table PersonAddress ( personId bigint not null, addressId bigint not null primary key )
create table Address ( addressId bigint not null primary key )

 

这样就可在many-to-one的情况下使用中间表了,且不需要中间表对应的entity . hibernate文档上貌似说此种方法不好

表的个数要小于实体的个数才可以????

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值