hibernate之映射关系一对多(自身关联)

自身关联注意的问题:
   1、关联多的一方必须是只有一个父类节点,如果存在多个父类节点,那么就不能采用自身关联,(字段冗余数据太多)
   2、自身关联可以节省表的设计、
   3、一的一端为父节点,没有外键
   4、多的一端为子节点,并且存在外键
   5、关联一对多自身关联外键key、mary-to-one、指向同一个对象同时也是同一外键字段
  代码配置:
  
   1、创建表
    create table t_user(
    u_id varchar(255),
    u_name varchar(255),
    u_age Integer,
    u_price double(5,2),
    uc_id varchar(255),//外键
    primary key(u_id)
    );
    
   2、java-pojo类
     public class UserT  implements Serializable{
     private String id;
     public String name;
     private Integer age;
     private double price;
     //父类
     private UserT userTsup;
     //子类
     private Set<UserT> userchild = new HashSet<UserT>();
     
     public UserT(){}
     省略get、set方法
     }
    3、配置文件
     <?xml version="1.0"?>
      <!DOCTYPE hibernate-mapping PUBLIC
              "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
              " http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
      
      <hibernate-mapping package="com.wolf.pojo.oneToone" auto-import="false">
          <class name="UserT" table="t_user">
          <!-- 多对一:只有单项    -->
              <id name="id" column="u_id">
              </id>
              <property name="name" column="u_name"/>
              <property name="age" column="u_age"/>
              <property name="price" column="u_price"/>
             
              <many-to-one name="userTsup" class="UserT" column="uc_id" lazy="false" cascade="all"></many-to-one>
           
           <set name="userchild" table="t_user" cascade="all" >
            <key column="uc_id"></key>
            <one-to-many class="UserT"/>
           </set>
          </class>
      </hibernate-mapping>

转载于:https://my.oschina.net/u/1041709/blog/897793

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值