zoukankan      html  css  js  c++  java
  • 八、多对一

    多对一

     

     

    1.根据上图对象模型创建pojo

    2.创建Employee.hbm.xmlDepartment.hbm.xml

    <?xml version="1.0" encoding="utf-8" ?>
    
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="com.myz.domain">
    
    <class name="Department">
    
    <!-- 主键 -->
    
    <id name="id" type="java.lang.Integer">
    
    <generator class="assigned" />
    
    </id>
    
     
    
    <property name="name" type="java.lang.String">
    
    <column name="name" length="64" not-null="true" />
    
    </property>
    
    </class>
    
    </hibernate-mapping>
    <?xml version="1.0" encoding="utf-8" ?>
    
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="com.myz.domain">
    
    <class name="Employee">
    
    <id name="id" type="java.lang.Integer">
    
    <generator class="assigned"></generator>
    
    </id>
    
     
    
    <property name="name" type="java.lang.String">
    
    <column name="name" length="64" not-null="true"></column>
    
    </property>
    
     
    
    <!-- 多对一,column表示将来自动生成的表的外键名称,默认与name一样 -->
    
    <many-to-one name="dept" column="dept_id"></many-to-one>
    
    </class>
    
    </hibernate-mapping>

     

    3.创建hibernate.cfg.xml(添加hbm2ddl.auto属性让hibernate自动创建数据库)

    <?xml version='1.0' encoding='UTF-8'?>
    
    <!DOCTYPE hibernate-configuration PUBLIC
    
              "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    
              "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
    
     
    
    <!-- Generated by MyEclipse Hibernate Tools.                   -->
    
    <hibernate-configuration>
    
     
    
    <session-factory>
    
    <property name="dialect">
    
    org.hibernate.dialect.MySQLDialect
    
    </property>
    
    <property name="connection.url">
    
    jdbc:mysql://localhost:3306/test
    
    </property>
    
    <property name="connection.username">root</property>
    
    <property name="connection.password">123456</property>
    
    <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
    
    <property name="myeclipse.connection.profile">mysql</property>
    
    <property name="show_sql">true</property>
    
    <property name="hbm2ddl.auto">update</property>
    
     
    
    <mapping resource="com/myz/domain/Department.hbm.xml" />
    
    <mapping resource="com/myz/domain/Employee.hbm.xml" />
    
     
    
    </session-factory>
    
    </hibernate-configuration>

    4.结果

    创建一个session,由于在加载hibernate.cfg.xml(Configuration().configure())会自动创建表,所以创建一个session时,自然表示加载过了配置文件。

    数据库变化:生成了两张表

    5.测试

    ts=session.beginTransaction();
    
    Employee e=new Employee();
    
    e.setId(1);
    
    e.setName("宋江");
    
    Department dept=new Department();
    
    dept.setId(1);
    
    dept.setName("财务部");
    
    e.setDept(dept);
    
     
    
    //先保存部门,再保存员工,其实先保存员工也是可以的,它会先把你的部门编号置空,然后在保存部门的时候,更新你的员工部门编号
    
    session.save(dept);
    
    session.save(e);
    
     
    
    ts.commit();
    
     
    
    此时只有员工指向了部门表,我们获得员工所在部门名称,可以直接 employee.getDept().getName(),而如果我们需要获取所有部门编号为1的员工, 可以
    
     
    
     
    
    String hql="from Employee where dept.id=1";
    
    //或者String hql="from Employee where dept_id=1";
    
    List<Employee> list = session.createQuery(hql).list();
    
    for(Employee e:list){
    
    System.out.println(e.getName());
    
    }
    
     
    
    而hibernate其实还可以反向查询,即在Department中通过一个集合来表示可以对应多个学生对象
  • 相关阅读:
    31个是你终生受用的爱情原则
    毕业后的五年拉开大家差距的原因在哪里?
    如何学习编程
    让人印象深刻的回答
    Android签名机制之---签名验证过程具体解释
    移动APP怎样保存用户password
    算法导论学习之线性时间求第k小元素+堆思想求前k大元素
    C#软件开发实例.私人订制自己的屏幕截图工具(十)在截图中包括鼠标指针形状
    Windows server 2003 + IIS6 搭建Asp.net MVC执行环境
    java移位运算符实验程序:&lt;&lt;(左移)、&gt;&gt;(带符 号右移)和&gt;&gt;&gt;(无符号右移)
  • 原文地址:https://www.cnblogs.com/myz666/p/8425030.html
Copyright © 2011-2022 走看看