原文地址:http://blog.csdn.net/qiaqia609/article/details/9456489html
hibernate.cfg.xmljava
XXX.hbm.xmlmysql
- <?xml version="1.0"?>
- <!DOCTYPE hibernate-mapping PUBLIC
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
-
- <!--
- <hibernate-mapping>通常不去配置,采用默认便可。
- default-cascade="none":默认的级联风格,表与表联动。
- default-lazy="true":默认延迟加载
- -->
- <hibernate-mapping>
-
- <!--
- <class>:使用class元素定义一个持久化类。
- name="cn.javass.user.vo.UserModel":持久化类的java全限定名;
- table="tbl_user":对应数据库表名;
- mutable="true":默认为true,设置为false时则不能够被应用程序更新或删除;
- dynamic-insert="false":默认为false,动态修改那些有改变过的字段,而不用修改全部字段;
- dynamic-update="false":默认为false,动态插入非空值字段;
- select-before-update="false":默认为false,在修改以前先作一次查询,与用户的值进行对比,有变化都会真正更新;
- optimistic-lock="version":默认为version(检查version/timestamp字段),取值:all(检查所有字段)、dirty(只检查修改过的字段)、
- none(不使用乐观锁定),此参数主要用来处理并发,每条值都有固定且惟一的版本,版本为最新时才能执行操做;
- -->
- <class name="cn.javass.user.vo.UserModel" table="tbl_user" dynamic-insert="true" dynamic-update="true" optimistic-lock="version">
-
- <!--
- <id>:定义了该属性到数据库表主键字段的映射。
- name="userId":标识属性的名字;
- column="userId":表主键字段的名字,若是不填写与name同样;
- -->
- <id name="userId">
- <!-- <generator>:指定主键由什么生成,推荐使用uuid(随机生成惟一通用的表示符,实体类的ID必须是String),
- native(让数据库自动选择用什么生成(根据底层数据库的能力选择identity,sequence或hilo中的一种)),
- assigned(指用户手工填入,默认)。 -->
- <generator class="uuid"/>
- </id>
-
- <!--
- <version/>:使用版本控制来处理并发,要开启optimistic-lock="version"和dynamic-update="true"。
- name="version":持久化类的属性名,column="version":指定持有版本号的字段名;
- -->
- <version name="version" column="version"/>
-
- <!--
- <property>:为类定义一个持久化的javaBean风格的属性。
- name="name":标识属性的名字,以小写字母开头;
- column="name":表主键字段的名字,若是不填写与name同样;
- update="true"/insert="true":默认为true,表示能够被更新或插入;
- -->
- <property name="name" column="name" />
- <property name="sex" column="sex"/>
- <property name="age" column="age"/>
-
- <!--
- 组件映射:把多个属性打包在一块儿当一个属性使用,用来把类的粒度变小。
- <component name="属性,这里指对象">
- <property name="name1"></property>
- <property name="name2"></property>
- </component>
- -->
-
- <!--
- <join>:一个对象映射多个表,该元素必须放在全部<property>以后。
- <join table="tbl_test:子表名">
- <key column="uuid:子表主键"></key>
- <property name="name1:对象属性" column="name:子表字段"></property>
- </join>
- -->
-
- </class>
-
- </hibernate-mapping>