用hibernate插入数据时怎么让默认值生效
来源:互联网 发布:单片机温湿度控制系统 编辑:程序博客网 时间:2024/05/22 07:56
数据库中一个字段的默认值设为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插入数据时怎么让默认值生效
- Hibernate插入数据到数据库中时让字段默认值生效
- Hibernate插入数据到数据库中时让字段默认值生效
- Hibernate使数据默认值生效
- Hibernate插入数据到数据库中时让数据库中的字段默认值生效
- hibernate向oracle插入数据 默认值没用
- hibernate映射数据库表如何在不插入值的情况下使表中字段默认值生效
- hibernate映射数据库表如何在不插入值的情况下使表中字段默认值生效
- Hibernate插入和修改数据到数据库中时不修改存在默认值字段
- Hibernate插入和修改数据到数据库中时不修改存在默认值字段
- 转载!!!Hibernate插入和修改数据到数据库中时不修改存在默认值字段
- 让插入数据类型为DateTime时没有系统默认值
- 使用Hibernate时,向数据库插入默认值的实现
- 使用Hibernate时,向数据库插入默认值的实现
- Hibernate插入数据时取字段的默认值,更新时只更新修改过的属性值
- Hibernate插入数据时取字段的默认值,更新时只更新修改过的属性值
- hibernate映射数据库表如何使表中字段默认值生效
- hibernate映射数据库表如何使表中字段默认值生效
- Android入门:EditText
- 【JS--基础--语句】--for in 循环遍历语句
- C 语言的可变参数表函数的设计
- VC++远程屏幕控制的分析1----软件初始架构
- java新学
- 用hibernate插入数据时怎么让默认值生效
- Linux中工作队列的实现(2.6.20的改变)
- 每天一本书不再是问题——快速阅读
- JSP入门
- tabsiplus即将发布新版本
- C# DataGridView禁止通过列排序
- 一个正整数表示为n(n>=2)个连续正整数之和!
- Linux2.4打开一个文件的系统调用
- C# request 获取完整URL