




























我们项目使用了NHibernate,为了体现ORM的优越性,领导决定把数据库从Oracle换成SQL Server,问题出现了,所有没有初始化的日期字段都不能正确保存,尽管这些字段允许Null。查了许多资料,终于发现日期字段必须使用 NuableDateTime类型,就像这样:
相应的HBM文件也要这么写:
<property name="DateOfBirth" type="Nullables.NHibernate.NullableDateTimeType, Nullables.NHibernate" />
这两种类型引用来自:Nullables.dll和Nullables.NHibernate.dll,可以在NHibernate contribution project.中找到。
如果使用出现异常:
"could not interpret type: Nullables.NHibernate.NullableDateTimeType,Nullables.NHibernate"异常? 那么你需要下载最新的Nhibernate。
不过我不知为什么Oracle中为什么没有这个问题。和Oracle的驱动程序有关吗?我还记得如果使用Ms的Oracle驱动时,连String类型也必须初始化,如果使用Oracle自己的驱动就没有这个问题。
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。