dynamic-insert="true" dynamic-update="true",插入默认值的情况

今天在做一个OA的简单增删除该查的时候,有一个时间类型的字段(数据插入时间),本身想着,这个字段直接中Oracle数据库设置一个Default Value ,就不用再前台install这个字段的值了,但是后时间操作中发现插入的时候如果不通过hql去写代码的话,而是通过hibernate的接口getHibernateTemplate().saveOrUpdate(entity);的话,就出现问题,插入的时间类型字段的值是null,tmd有点郁闷,不好意思又说脏话了,也是当时头有点昏,呵呵。后来,一想如果通过getHibernateTemplate().saveOrUpdate(entity);这个借口,如果没有设置值,那么就会设置null,所有出现了这个问题。查看了下hibernate的接口文档,一看,原来是这样的。

需要添加下面的参数在*.hbm.xml中class节点设置,如下

一是将dynamic-insert设置为true

二是将对应字段的属性设置not-null为false

<hibernate-mapping>
<class name="com.tom.hibernate.xxxx" table="xxx schema="xxx" dynamic-insert="true" dynamic-update="true">

<property name="entryDate" type="java.util.Date">
<column name="ENTRY_DATE" length="7" not-null="false"/>
</property>

用拿来主义)贴过来一个这个接口说明:

下面是有关其它配置的说明

Hibernate允许我们在映射文件里控制insert和update语句的内容.比如在映射文件中<property 元素中的update属性设置成为false,那么这个字段,将不被包括在基本的update语句中,修改的时候,将不包括这个字段了.insert同理.dynamic动态SQL语句的配置也是很常用的.下面介绍配置SQL语句的具体属性:
1)<property>元素 insert属性:设置为false,在insert语句中不包含这个字段,表示永远不会被插入,默认true
2)<property>元素 update属性:设置为false,在update语句中不包含这个字段,表示永远不会被修改,默认true
3)<class>元素 mutable属性:设置为false就是把所有的<property>元素的update属性设置为了false,说明这个对象不会被更新,默认true
4)<property>元素 dynamic-insert属性:设置为true,表示insert对象的时候,生成动态的insert语句,如果这个字段的值是null就不会加入到insert语句当中.默认false
5)<property>元素 dynamic-update属性,设置为true,表示update对象的时候,生成动态的update语句,如果这个字段的值是null就不会被加入到update语句中,默认false
6)<class>元素 dynamic-insert属性:设置为true,表示把所有的<property>元素的dynamic-insert属性设置为true,默认false
7)<class>元素 dynamic-update属性:设置为true,表示把所有的<property>元素的dynamic-update属性设置为true,默认false

Hibernate生成动态SQL语句的消耗的系统资源(比如CPU,内存等)是很小的,所以不会影响到系统的性能,如果表中包含N多字段,建议把dynamic-update属性和insert属性设置为true,这样在插入和修改数据的时候,语句中只包括要插入或者修改的字段.可以节省SQL语句的执行时间,提高程序的运行效率.

另外一种做法请看如下配置:

Hibernate <property>配置
<property name="name" unique="true" not-null="true" update="false" length="25"/>

<property>元素 insert属性:设置为false,在insert语句中不包含这个字段,表示永远不会被插入。默认true。

<property>元素 update属性:设置为false,在update语句中不包含这个字段,表示永远不会被修改。默认true。

<class>元素 mutable属性:设置为false,就是把所有的<property>元素的update属性设置为了false,说明这个对象不会被更新。默认true。

<property>元素 dynamic-insert属性:设置为true,表示insert对象的时候,生成动态的insert语句,如果这个字段的值是null就不会加入到insert语句当中。默认false

<property>元素 dynamic-update属性:设置为true,表示update对象的时候,生成动态的update语句,如果这个字段的值是null就不会被加入到update语句中。默认false

<class>元素 dynamic-insert属性:设置为true,表示把所有的<property>元素的dynamic-insert属性设置为true。默认false

<class>元素 dynamic-update属性:设置为true,表示把所有的<property>元素的dynamic-update属性设置为true。默认false

dynamic-update,如果一个表字段比较多,并且经常只是更新一条记录的一两个字段,避免了过多无用的sql语句,动态更新会更有效。应用程序会增加工作量,但是数据库会减少工作量。在插入和修改数据的时候,语句中只包括要插入或者修改的字段,可以节省SQL语句的执行时间,提高程序的运行效率。
本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2012-11/74542.htm
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
-fira-algorithm=CB是一种基于域的内联优化,它会检查每个域中的函数,并根据其可能的域特性和关系来决定内联哪些函数。它可以有效地避免潜在的低效内联,提高程序性能。 -fira-region=one是一种基于区域的内联优化,它将整个程序分解为一个或多个区域,并优化每个区域独立进行内联。 -flifetime-dse=2是一种用于处理变量和内存空间的优化算法,它会分析变量的生存期并对存储空间进行优化,从而减少内存的使用。 -freorder-blocks-algorithm=stc是一种基于统计的块重排优化算法,它会根据代码的使用情况和块的特征重新排列块,从而有效提高程序性能。 -fstack-reuse=none是一种用于控制堆栈空间分配的优化选项,它可以有效地避免在程序中过度分配堆栈空间,从而减少内存的使用。 -fvect-cost-model=dynamic是一种用于控制矢量化的优化选项,它会根据环境和代码的特征动态地调整矢量化的代价,从而提高程序性能。 -fbranch-target-load-optimize2是一种用于控制分支预测的优化选项,它会尝试更好地推测分支的结果,从而提高程序性能。 -fno-gcse-after-reload是一种禁用基于重新加载的全局代码搜索和优化的选项,它可以有效地避免重新加载过程中可能存在的低效性能问题。 -fno-live-range-shrinkage是一种禁用范围缩小的优化选项,它可以有效地避免过度缩小变量的使用范围,从而提高程序性能。 -fsched-spec-load是一种指定加载器的优化选项,它会根据给定的参数对载入器进行优化,从而提高程序性能。 -ftree-loop-distribute-patterns是一种用于优化循环体的选项,它会根据循环体的模式进行优化,从而降低程序运行时间。 -funswitch-loops是一种用于控制循环展开的优化选项,它会尝试优化循环展开,以减少编译时间。 -fsimd-cost-model=unlimited是一种用于控制SIMD的优化选项,它会尝试在程序中使用SIMD指令来提高程序性能,并且不限制SIMD指令的使用数量。 -fno-associative-math是一种禁用关联运算的优化选项,它可以有效地避免在程序中使用关联运算,从而提高程序性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值