使用NHibernate插入NULL值到数据库

一般情况下,我们在mapping时,会像这样写:

……

<property name="Name" column="NAME" type="String" length="30" />

<property name="Age" column="AGE" type="Int32" />

<property name="BirthDate" column="BIRTHDATE" type="DateTime" />

……

NHibernate在持久化对象时,如果要插入NULL值就不太容易了,你必须对持久化对象的每个映射属性赋值,但对于DateTime类型的属性就更加麻烦了,由于ADO.NET对于插入的DateTime值有范围限制(1753-1-1 0:00:00到9999-12-31 23:59:59),否则会throw异常。所以在项目中我用1899-1-1 0:00:00来替代NULL值,可是总觉得不爽,在代码中总要作些判断,转换。于是see NHibernate Reference,果然有所发现。

NHibernate提供了Nullable的支持,对于每种数据类型都有对应的Nullable class(in Nullables.dll & Nullables.Nhibernate.dll)。如果希望插入NULL值,那么在对应的属性所映射的type中改为如下形式(修改上例)

……

<property name="Name" column="NAME" type="Nullables.NHibernate.NullableStringType, Nullables.NHibernate" length="30" />

<property name="Age" column="AGE" type="Nullables.NHibernate.NullableIntegerType, Nullables.NHibernate" />

<property name="BirthDate" column="BIRTHDATE" type="Nullables.NHibernate.NullableDateTimeType, Nullables.NHibernat" />

……

同样,在对应的POJO文件中,改成这样:

private Nullables.NullableString name;

private Nullables.NullableDateTime birthDate;



……(其他属性略,Getter & Setter略)
OK,现在在代码中,我们即使不对某个DateTime,String类型的属性赋值,持久化到数据库中的值就是NULL了。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值