likes
comments
collection
share

hibernate映射文件详解

作者站长头像
站长
· 阅读数 3

hibernate映射文件

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

<?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的反射机制来直接访问类的属性

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

设置派生属性

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

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

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

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来提升性能

zhhll.icu/2020/框架/hib…

本文由mdnice多平台发布