gpt4 book ai didi

oracle - Oracle 数据库的 NHibernate 映射导致 StaleStateException

转载 作者:行者123 更新时间:2023-12-02 08:50:12 28 4
gpt4 key购买 nike

我们有一个 NHibernate 应用程序,正在从 SQL Server 迁移到 Oracle。我们的乐观并发是通过 <timestamp name="Version"> 实现的映射元素。

对应Version的数据类型Oracle 中的列是 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>映射到 DATE 类型的 Oracle 列或TIMESTAMP这样同一个对象可以保存多次?

谢谢。

--布莱恩

最佳答案

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

关于oracle - Oracle 数据库的 NHibernate <timestamp> 映射导致 StaleStateException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4496766/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com