实体类(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值一样。-->
如果对你有帮助,下次再见,嘻嘻