• Hibernatede 一对多映射配置


    Hibernatede 一对多映射配置

    以公司和员工为例:公司是一,员工是多

     

    第一步 创建两个实体类,公司和员工

           写核心配置文件hibernate.cfg.xml

           写映射配置文件Company.hbm.xml 和Worker.hbm.xml

     

    第二步 让两个实体类之间互相表示

    (1)在公司实体类里面表示拥有多个员工,把员工的集合作为属性,写入公司的实体类。

    //在公司实体类里面表示拥有多个员工,一个公司有多个员工

           //hibernate要求使用集合表示多的数据,使用set集合

    private Set<Worker> workers=new HashSet<Worker>();

     

         public Set<Worker> getWorkers() {

            return workers;

         }

        public void setWorkers(Set<Worker> workers) {

            this.workers = workers;

         } 

     

    (2)在员工实体类里面表示所属公司

    - 一个员工只能属于一个公司

    // 在员工实体类里面表示所属公司,一个员工只能属于一个公司,把公司类作为员工的一个属性,写入员工类。

    private Company company;

     

        public Company getCompany() {

            return company;

           }

     

        public void setCompany(Company company) {

            this.company = company;

           }

     

    第三步 配置映射关系

    (1)一个实体类对应一个映射文件

    (2)把映射最基本的配置完成

     

    (3)在映射文件中,配置一对多关系

    - 在公司映射文件中,配置所有的员工

    1  set标签(class标签的子标签)表示员工的集合

        name属性: 属性值写的是公司实体类里面表示员工的set集合名称

    2  key标签(set标签的子标签) 

    column属性值:外键名称

    3  one-to-many标签(set标签的子标签):

    class属性:里面写多的一方的实体类全路径(即员工类)

    代码:

    <set name="workers">

             <key column="c_w_id"/>

    <one-to-many class="entity.Worker"/>

    </set>

     

    - 在员工映射文件中,配置其所属公司

    使用many-to-one标签(class标签的子标签),表示员工所属公司

                  1     name属性:因为在员工实体类使用company对象表示,写company名称

                  2     class属性:Company全路径

                  3     column属性:外键名称(要和公司映射文件中的外键名称保持一致)

    代码:         

    <many-to-one 

    name="company" class="entity.Company" column="c_w_id">

    </many-to-one>

     

    第四步 创建核心配置文件,把映射文件引入到核心配置文件中

    <!-- 第三部分: 把映射文件放到核心配置文件中 必须的-->

     <mapping resource=" entity/Company.hbm.xml"/>

  • 相关阅读:
    tensorflow学习之路---Session、Variable(变量)和placeholder
    tensorflow学习之路---简单的代码
    python之路:发附带文件的邮件
    pythong中的全局变量的调用和嵌套函数中变量的使用
    python字符串
    Python之路:画空心矩形
    ajax jsonp请求报错not a function的解决方案
    《beyond jquery》读书笔记1
    移动端video标签默认置顶的解决方案
    css中的视距perspective和视差效果
  • 原文地址:https://www.cnblogs.com/ncl-960301-success/p/7535430.html
Copyright © 2020-2023  润新知