用hibernate插入数据时怎么让默认值生效
2012-05-20 21:51
274 查看
数据库中一个字段的默认值设为0,当用hibernate插入数据时,没有对该字段进行操作,结果该字段居然不是0,而是空。后来google了一下,发现应该在.hbm.xml文件中添加一些参数定义(示例中的红色部分),具体如下:
<hibernate-mapping>
<class name="com.tom.hibernate.EbayItem" table="EBAY_ITEM" schema="API_USER"
dynamic-insert="true" dynamic-update="true">
.......
........
</class>
</hibernate-mapping>
下面是有关其它配置的说明
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-mapping>
<class name="com.tom.hibernate.EbayItem" table="EBAY_ITEM" schema="API_USER"
dynamic-insert="true" dynamic-update="true">
.......
........
</class>
</hibernate-mapping>
下面是有关其它配置的说明
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插入数据到数据库中时让数据库中的字段默认值生效
- hibernate 插入数据时让数据库默认值生效
- Hibernate插入数据到数据库中时让字段默认值生效
- Hibernate插入数据到数据库中时让字段默认值生效
- hibernate映射数据库表如何在不插入值的情况下使表中字段默认值生效
- hibernate映射数据库表如何在不插入值的情况下使表中字段默认值生效
- hibernate怎么得到插入数据的主键 或者自动增值的id
- hibernate或SSH框架怎么在插入数据后拿到自动递增主键的GeneratedKey?
- Hibernate插入和修改数据到数据库中时不修改存在默认值字段
- 怎么使用class使用hibernate的插入数据到数据库
- 小学生之Hibernate插入数据修改数据使用数据库默认值的实现
- hibernate向oracle插入数据 默认值没用
- hibernate批量数据插入优化 ------用Hibernate插入1万条数据,怎么做,有什么好的优化方法吗
- Hibernate使数据默认值生效
- hibernate怎么得到插入数据的主键 或者自动增值的id
- Hibernate插入和修改数据到数据库中时不修改存在默认值字段
- 转载!!!Hibernate插入和修改数据到数据库中时不修改存在默认值字段
- 使用Hibernate如何在Oracle中插入Date类型的数据
- hibernate级联操 同时向2张表插入数据(一对多的关联,一个简单的例子说明)
- hibernate 实行原生sql insert数据无法插入到数据库