zoukankan      html  css  js  c++  java
  • hibernate之关于使用连接表实现多对一关联映射


    【Hibernate】之关于使用连接表实现多对一关联映射


    在我们项目使用中採用中间表最多的一般就是多对一,或者是多对多,当然一对一使用中间表也是能够的,可是这样的几率通常少之又少!所以这里重点介绍多对一和一对多的採用中间表进行关联映射!


    依旧採用Group和Person来描写叙述这个逻辑!


    Annotations配置

    @Entity
    @Table(name="t_group")
    publicclass Group {
        private Integer id;
        private String name;
        @Id
        @GeneratedValue
        public Integer getId() {
           returnid;
        }
        publicvoid setId(Integer id) {
           this.id = id;
        }
        @Column(name="g_name")
        public String getName() {
           returnname;
        }
        publicvoid setName(String name) {
           this.name = name;
        }
    }

    @Entity
    @Table(name="p_person")
    publicclass Person {
        private Integer id;
        private String name;
        private Integer age;
        private Group group;
        @ManyToOne
        //以下是配置中间表的核心
        @JoinTable(name="g_p",joinColumns={@JoinColumn(name="p_id")},
               inverseJoinColumns={@JoinColumn(name="g_id")})
        public Group getGroup() {
           returngroup;
        }
        publicvoid setGroup(Group group) {
           this.group = group;
        }
        @Id
        @GeneratedValue
        public Integer getId() {
           returnid;
        }
        publicvoid setId(Integer id) {
           this.id = id;
        }
        @Column(name="p_name")
        public String getName() {
           returnname;
        }
        publicvoid setName(String name) {
           this.name = name;
        }
        @Column(name="p_age")
        public Integer getAge() {
           returnage;
        }
        publicvoid setAge(Integer age) {
           this.age = age;
        }
    }


    XML配置


    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC 
        "-//Hibernate/HibernateMapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    <hibernate-mapping package="csg.hibernate.entity">
        <class name="Person" table="t_person">
           <id name="id">
               <column name="id"/>
               <generator class="native" />
           </id>
           <property name="name" />
           <property name="age" />
           <join table="t_p" optional="true">
               <key column="p_id"></key>
               <many-to-one name="group" column="g_id" class="Group" unique="true"/>
           </join>
        </class>
    </hibernate-mapping>

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC 
        "-//Hibernate/HibernateMapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    <hibernate-mapping package="csg.hibernate.entity">
        <class name="Group" table="t_group">
           <id name="id">
               <column name="id"/>
               <generator class="native" />
           </id>
           <property name="name" />
        </class>
    </hibernate-mapping>


    写这篇文章,我特意查询了一下网上的文章,发现大家都是採用XML配置的,所以我这里也写了Annotations配置,由于JPA中的Annotations使用起来远比XML要方便!OK?







    XML配置


  • 相关阅读:
    在oracle中通过connect by prior来实现递归查询!
    c# System.Data.OracleClient需要Oracle客户端软件8.1.7或更高版本
    c# 水晶报表的设计(非常的基础)
    webapi+EF(增删改查)
    简单三层分页aspnetpager控件(欢迎指点)
    listbox 多选删除(找了好多都不行,终于让我写出来了)
    execl导出(HTML,repearter控件)
    SQL Server中截取字符串常用函数
    几个经常用到的字符串的截取
    gridview的增删改
  • 原文地址:https://www.cnblogs.com/yxwkf/p/4551002.html
Copyright © 2011-2022 走看看