3

我们有一个 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可以多次保存同一个对象?

谢谢。

——布赖恩

4

1 回答 1

4

TIMESTAMP(7) 具有与 .NET DateTime 类匹配的正确精度并解决了该问题。

于 2011-01-22T04:04:24.523 回答