实体类(User)

package com.hibernate.entity;

import java.io.Serializable;

public class User implements Serializable {
        private String uid;
        private String name;
        private  String password;
        private  Integer age;
        private  Integer version;

   // ...此处省略getter和setter
}

对应的配置文件(User.hbm.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 >
    <!--  name -> 实体类   table -> 数据表   -->
    <class name="com.hibernate.entity.User" table="user">
        <!-- id主键  -->
        <id name="uid" column="uid">
             <!-- 主键生成模式  -->
            <generator class="uuid"></generator>
        </id>
        <!--乐观锁  防止更新丢失  位置必须在这-->
        <version name="version"></version>

        <property name="name" column="name"/>
        <property name="password" column="password"></property>
        <property name="age" column="age"></property>
    </class>
</hibernate-mapping>

generator 说明

<!--本文讲述Hibernate的generator属性的意义。Generator属性有7种class,本文简略描述了这7种class的意义和用法。-->
<!--Hibernate的Generator属性有7种class,本文简略描述了这7种class的意义和用法。-->
<!--1、identity:用于MySql数据库。特点:递增 -->
< id name="id" column="id">   
    < generator class="identity"/>   
< /id> 
<!--注:对于MySql数据库使用递增序列时需要在建表时对主键指定为auto_increment属性。-->
    
<!--2、sequence:用于Oracle数据库 -->
< id name="id" column="id">   
   < generator class="sequence">   
     < param name="sequence">序列名< /param>   
   < /generator>   
< /id> 
    
<!--3、native:跨数据库时使用,由底层方言产生。
    Default.sequence为hibernate_sequence--> 
< id name="id" column="id">   
   < generator class="native"/>   
< /id>   
<!--注:使用native时Hibernate默认会去查找Oracle中的hibernate_sequence序列。 
		如果Oracle中没有该序列,连Oracle数据库时会报错。--> 
    
<!--4、hilo:通过高低位合成id,先建表hi_value,再建列next_value。必须要有初始值。--> 
< id name="id" column="id">   
    < generator class="hilo">   
      < param name="table">high_val< /param>   
       < param name="column">nextval< /param>   
      < param name="max_lo">5< /param>   
    < /generator>   
< /id>  
<!-- 5、sequencehilo:同过高低位合成id,建一个sequence序列,不用建表。--> 
< id name="id" column="id">   
< generator class="hilo">   
< param name="sequence">high_val_seq< /param>   
< param name="max_lo">5< /param>   
< /generator>   
< /id> 
<!--6、assigned:用户自定义id; -->
< id name="id" column="id">   
< generator class="assigned"/>   
< /id> 
<!--7、foreign:用于一对一关系共享主健时,两id值一样。-->
posted on 2020-11-22 22:38  人生之外的路途  阅读(168)  评论(0编辑  收藏  举报