码迷,mamicode.com
首页 > Web开发 > 详细

Hibernate--使用xml配置映射关系

时间:2017-10-27 17:55:32      阅读:245      评论:0      收藏:0      [点我收藏+]

标签:encoding   1.0   inverse   ppi   tab   batch   map   logs   文件   

 

写在前面:

  配置实体类与数据库的映射关系,有两种方式:

  1.使用*.hbm.xml       

   2.使用@注解

 

   二:xml的配置方式:

  eg:员工的xml配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
        ‘-//Hibernate/Hibernate Mapping DTD 3.0//EN‘
        ‘http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd‘>
<hibernate-mapping>
    
   <class name="edu.hue.erp.auth.emp.vo.EmpModel" table="tbl_emp">
           <!-- id为主键的配置:
           id-name:实体类中的属性名
           column-name:数据库表中主键名
           generator-class:主键生成策略 -->
           <id name="uuid" >
               <!-- 数据库表中主键字段名与实体类的属性名相同时,column可以省略不写 -->
               <!-- <column name="uuid"></column> -->
               <generator class="native"></generator>
           </id>
           
           <!-- property:非主键属性的配置
           property-name:实体类中属性名
           column-name:实体类中属性对应的数据库表中字段名
            -->
           <!-- 数据库表中主键字段名与实体类的属性名相同时,column可以省略不写 -->
           <!-- <property name="username">
               <column name="username"/>
           </property> -->
           <property name="username"/>
           <property name="pwd"/>
           <property name="name"/>
           <property name="tele"/>
           <property name="address"/>
           <property name="email"/>
           <property name="gender"/>
           <property name="birthday"/>
           <property name="lastLoginTime"/>
           <property name="lastLoginIp"/>
           <property name="loginTimes"/>
           
           <!-- 员工对部门 多对一的关系 -->
           <!-- name:与员工实体类中含有的部门对象名一致
           column:员工表中的外键(部门的主键)
           class:一方 中 类的全路径 -->
           <many-to-one 
               name="dm"
               column="depUuid" 
               class="edu.hue.erp.auth.dep.vo.DepModel"
           />
           
           <!-- 员工对角色 多对多 -->
           <!-- name:与员工实体类中含有的角色对象名一致
           table:中间表名
           key-column:员工表的主键
           many-to-many--column:角色主键
           many-to-many--class:角色类的全路径 -->
           <set name="roles" table="tbl_emp_role">
               <key column="empUuid"/>
               <many-to-many column="roleUuid" class="edu.hue.erp.auth.role.vo.RoleModel"/>
           </set>
           
           
           
   </class>
</hibernate-mapping>
<!-- 另外补充在部门的配置文件中:

         //部门对员工  一对多 
        //private Set<Employee> emps;
        
         当进行级联删除时
           一方对象首先要放弃与多方之间的关系,转化为将外键字段设置为null
           如果此时外键字段设置为不允许为null,引发下列异常 
           java.sql.BatchUpdateException:Column ‘depUuid‘ cannot be null
           此时只需要在进行关系维护时,使一方对象不对关系进行维护即可,不操作外键——————inverse=true
           
           <set name="emps" cascade="delete" inverse="true">
               <key column="depUuid"/>
               <one-to-many class="edu.hue.erp.auth.emp.vo.EmpModel"/>
           </set>
           //注意部门对员工一对多与员工对部门多对一中的column是一致的
 -->

 

天啦 真是丧尽天良啊。。。。少于150字不允许被发布出去不允许被发布出去不允许被发布出去。。。。。。。。。。

真的是,难道插入的代码不算字数的么。。。。。好。。很好。。。那我们就来一起凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑

凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑凑

够这150字。。。

 

 

 

 

Hibernate--使用xml配置映射关系

标签:encoding   1.0   inverse   ppi   tab   batch   map   logs   文件   

原文地址:http://www.cnblogs.com/eleven258/p/7743546.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!