hibernate 新增字段设置默认值

hibernate 新增字段设置默认值,第1张

今天终于把这个问题给解决了。。呵呵,

hibernate

注解字段默认值的设置:

@column(name="ispublic"

,nullable=false,columndefinition="int

default

0")

private

int

ispublic

注意字段的类型必须指定,因为hibernate

会把columndefinition

的内容直接写在生成标的ddl中,因此语法必须正确。小记一下,以防忘记。

hibernate映射数据库表如何使表中字段默认值生效

纯杰宗の0002 | 浏览 2133 次

推荐于2016-02-04 08:55:26最佳答案

解决方法: 在hibernate映射文件对数据库表的描述中,在当前字段处加入insert="false"语句,这时hibernate在进行插入 *** 作时,只会为那些有实值的字段赋值,而值为空白的字段就会使用数据库表中定义的默认值了。

举例说明,表person:

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

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

CREATE TABLE address (

i_id int(11) NOT NULL auto_increment,

c_address varchar(100) NOT NULL default '中国',

PRIMARY KEY (id)

)

address.hbm.xml:

<hibernate-mapping package="cn.com.lough.model">

<class

name="address "

table="address "

lazy="false"

>

<meta attribute="sync-DAO">true</meta>

<cache usage="read-write"/>

<id

name="IId"

type="integer"

column="i_id"

>

<generator class="native"/>

</id>

<property

name="C_Address"

column="c_address "

type="string"

not-null="false"

length="128"

/>

</hibernate-mapping>

运行程序

public regAddress(String a){ //传入的值a未在网页文本框里获得任何值(家庭地址)

Address p = new Address ()

p.setAddress(a)

HiFactory.save(p)

}

此时hibernate生成的sql语句为insert into person(c_address) values('')

数据库表结果为

i_id c_address

1 null

修改address.hbm.xml为:

<hibernate-mapping package="cn.com.lough.model">

<class

name="Address"

table="address"

lazy="false"

>

<meta attribute="sync-DAO">true</meta>

<cache usage="read-write"/>

<id

name="IId"

type="integer"

column="i_id"

>

<generator class="native"/>

</id>

<property

name="C_Address"

column="c_address"

type="string"

not-null="false"

length="128"

insert="false"

/>

</hibernate-mapping>

再次运行程序,此时hibernate生成的sql语句为 insert into address() values()

数据库中一个字段的默认值设为0,当用hibernate插入数据时,没有对该字段进行 *** 作,结果该字段居然不是0,而是空。后来google了一下,发现应该在.hbm.xml文件中添加一些参数定义(示例中的红色部分),具体如下:<hibernate-mapping<class name=com.tom.hibernate.EbayItem table=EBAY_ITEM schema=API_USERdynamic-insert=true dynamic-update=true........</class</hibernate-mapping下面是有关其它配置的说明Hibernate允许我们在映射文件里控制insert和update语句的内容.比如在映射文件中<property 元素中的update属性设置成为false,那么这个字段,将不被包括在基本的update语句中,修改的时候,将不包括这个字段了.insert同理.dynamic动态SQL语句的配置也是很常用的.下面介绍配置SQL语句的具体属性:1)<property元素 insert属性:设置为false,在insert语句中不包含这个字段,表示永远不会被插入,默认true2)<property元素 update属性:设置为false,在update语句中不包含这个字段,表示永远不会被修改,默认true3)<class元素 mutable属性:设置为false就是把所有的<property元素的update属性设置为了false,说明这个对象不会被更新,默认true4)<property元素 dynamic-insert属性:设置为true,表示insert对象的时候,生成动态的insert语句,如果这个字段的值是null就不会加入到insert语句当中.默认false5)<property元素 dynamic-update属性,设置为true,表示update对象的时候,生成动态的update语句,如果这个字段的值是null就不会被加入到update语句中,默认false6)<class元素 dynamic-insert属性:设置为true,表示把所有的<property元素的dynamic-insert属性设置为true,默认false7)<class元素 dynamic-update属性:设置为true,表示把所有的<property元素的dynamic-update属性设置为true,默认falseHibernate生成动态SQL语句的消耗的系统资源(比如CPU,内存等)是很小的,所以不会影响到系统的性能,如果表中包含N多字段,建议把dynamic-update属性和insert属性设置为true,这样在插入和修改数据的时候,语句中只包括要插入或者修改的字段.可以节省SQL语句的执行时间,提高程序的运行效率.


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/bake/7983212.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-12
下一篇2023-04-12

发表评论

登录后才能评论

评论列表(0条)

    保存