我们有一个 NHibernate 应用程序,我们正在从 SQL Server 迁移到 Oracle。我们的乐观并发是通过<timestamp name="Version">
映射元素实现的。
Oracle中对应Version
列的数据类型为DATE
. 保存对象后,内存中的 C# 对象会留下一个以毫秒为单位的时间戳值(例如 12:34:56.789),而数据库中的值仅精确到秒(例如 12:34:56)。因此,如果我们第二次尝试保存对象,我们会收到 StaleStateException,因为这两个值不匹配。
我试图通过将Version
列的数据类型更改为TIMESTAMP(3)
. 不幸的是,C# 对象和 DB 值仍然相差一毫秒(例如 12:34:56.789 与 12:34:56.788),因此第二次尝试保存对象仍然会导致 StaleStateException。
我可以做些什么来创建<timestamp>
到类型的 Oracle 列的工作映射,DATE
或者TIMESTAMP
可以多次保存同一个对象?
谢谢。
——布赖恩