NHibernate日期类型的映射

我们项目使用了NHibernate,为了体现ORM的优越性,领导决定把数据库从Oracle换成SQL Server,问题出现了,所有没有初始化的日期字段都不能正确保存,尽管这些字段允许Null。查了许多资料,终于发现日期字段必须使用 NuableDateTime类型,就像这样:
public NullableDateTime DateOfBirth
        
{
            
get return dateOfBirth; }
            
set { dateOfBirth = value; }
        }


相应的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自己的驱动就没有这个问题。
posted @ 2005-07-06 22:30  行知  阅读(3023)  评论(13编辑  收藏  举报