NHibernate + Oracle:如何避免插入时的毫秒截断

时间:2014-08-25 16:14:18

标签: oracle nhibernate oracleclient

映射文件:

<?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中没有毫秒。

1 个答案:

答案 0 :(得分:0)

经过更多调查后,我尝试将Oracle客户端驱动程序(ODAC 12c Release 2 12.1.0.1.2 Xcopy)更新为可用的最新版本,这解决了我的问题。似乎与较旧的Oracle驱动程序有关。