映射文件:
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="OracleHibernateTest" namespace="OracleHibernateTest">
<class name="TableRow" table="TIMESTAMP_TEST_2">
<id name="Id" />
<property name="Time" type="Timestamp">
<column name="TIME" sql-type="TIMESTAMP(4)"></column>
</property>
</class>
</hibernate-mapping>
代码:
var configuration = new Configuration();
configuration.Configure();
var export = new SchemaExport(configuration);
export.Create((s) => Trace.WriteLine(s), true);
var sessionFactory = configuration.BuildSessionFactory();
using (var session = sessionFactory.OpenSession())
{
var testItem = new TableRow() { Id = (new Random().Next()), Time = new DateTime(2014, 8, 25, 5, 12, 4, 587) };
session.Save(testItem);
session.Flush();
}
上面的代码将插入新行,但“时间”列中的毫秒将被截断。
从调查中我发现NHibernate将使用参数创建OracleParameter for SQL命令,其中OracleType设置为DateTime而不是TimeStamp。 在Oracle DateTime中没有毫秒。
答案 0 :(得分:0)
经过更多调查后,我尝试将Oracle客户端驱动程序(ODAC 12c Release 2 12.1.0.1.2 Xcopy)更新为可用的最新版本,这解决了我的问题。似乎与较旧的Oracle驱动程序有关。