NHibernate日期类型的映射
我们项目使用了NHibernate,为了体现ORM的优越性,领导决定把数据库从Oracle换成SQL Server,问题出现了,所有没有初始化的日期字段都不能正确保存,尽管这些字段允许Null。查了许多资料,终于发现日期字段必须使用 NuableDateTime类型,就像这样:
相应的HBM文件也要这么写:
这两种类型引用来自:Nullables.dll和Nullables.NHibernate.dll,可以在NHibernate contribution project.中找到。
如果使用出现异常:
"could not interpret type: Nullables.NHibernate.NullableDateTimeType,Nullables.NHibernate"异常? 那么你需要下载最新的Nhibernate。
不过我不知为什么Oracle中为什么没有这个问题。和Oracle的驱动程序有关吗?我还记得如果使用Ms的Oracle驱动时,连String类型也必须初始化,如果使用Oracle自己的驱动就没有这个问题。
public NullableDateTime DateOfBirth
{
get { return dateOfBirth; }
set { dateOfBirth = value; }
}
{
get { return dateOfBirth; }
set { dateOfBirth = value; }
}
相应的HBM文件也要这么写:
<property name="DateOfBirth" type="Nullables.NHibernate.NullableDateTimeType, Nullables.NHibernate" />
如果使用出现异常:
"could not interpret type: Nullables.NHibernate.NullableDateTimeType,Nullables.NHibernate"异常? 那么你需要下载最新的Nhibernate。
不过我不知为什么Oracle中为什么没有这个问题。和Oracle的驱动程序有关吗?我还记得如果使用Ms的Oracle驱动时,连String类型也必须初始化,如果使用Oracle自己的驱动就没有这个问题。