0%

hibernate映射文件

hibernate映射文件

映射文件在.hbm.xml文件中编写

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!-- 根元素 -->
<hibernate-mapping>
<!--
dynamic-update 动态修改 仅修改需要更新的字段
dynamic-insert 动态插入 只会插入不为null的字段
-->
<!-- class标签用来定义java类到数据库表的映射关系 -->
<class name="com.zhanghe.study.model.User" table="user" dynamic-update="true" dynamic-insert="true">
<cache usage="read-write"/>
<id name="id" type="java.lang.Integer">
<column name="id"/>
<!-- 指定主键生成方式 navive 使用数据库本地方式 -->
<!-- 主键生成方式
increment Hibernate一递增的方式赋值 先查该表的id最大值,再加一 存在并发问题
identity 由底层数据库生成,需要把主键设置为自增的
sequence 底层数据库序列生成
hilo 由hibernate按照一种high/low算法生成,从数据库中特定表的字段中获取high值
native 根据底层数据库对自动生成主键的支持能力,来选择identity,sequence或hilo生成器
-->
<generator class="native"/>
</id>

<!--
access 表示属性访问策略,默认为property,使用getter/setter来访问赋值
field 使用反射访问成员变量

unique 是否为唯一约束
update 表示该字段是否能修改
index 索引
length 长度
-->
<property name="name" type="java.lang.String" not-null="true" access="property">
<column name="name"/>
</property>
<property name="age" type="java.lang.Integer">
<column name="age"/>
</property>

</class>
</hibernate-mapping>

配置访问持久化类属性的策略

可以在property元素中配置access属性来指定hibernate访问持久化类属性的方式

  • property 默认值,使用getter/setter方法来访问类的属性,不需要管有没有该成员变量

  • field 使用java的反射机制来直接访问类的属性

1
2
3
<property name="customerName" type="java.lang.String" access="property">
<column name="customer_name"/>
</property>

设置派生属性

有些属性的值需要在运行时进行计算才可以获取到,此时可以使用property元素的formula属性,该属性用来设置一个SQL表达式,hibernate根据SQL来计算出派生属性的值

1
<property name="totalPrice" formula="(select sum(price) from orders where custom_id=id)"></property>

在查询的时候就会进行拼接子查询来获取该属性的值

1
select id,name,(select sum(price) from orders where custom_id=1) from customer where id = 1;

控制字段的插入和更新

hibernate生成的save()、update()语句默认是插入和更新全部的字段,可以进行自定义设置

  • property元素的insert属性 默认为true,如果设置为false,表示insert语句中不包含该字段
  • property元素的update属性 默认为true,如果设置为false,表示update语句中不包含该字段
  • class元素的mutable属性 默认为true,如果设置为false,等价于该类下所有的property元素的update属性为false,整个实例都不可以被更新
  • class属性的dynamic-insert属性 默认为false,如果为true,表示当保存一个对象时,会动态的生成insert语句,仅包含取值不为null的字段
  • class属性的dynamic-update属性 默认为false,如果为true,表示当更新一个对象时,会动态的生成update语句,仅包含需要更新的字段

注意:当表的字段比较多时,可以设置dynamic-insert、dynamic-update来提升性能