问题描述
嗨
数字 (32,16) 数据类型列的行为不同,当我们更新这些列时,oracle会自动将值四舍五入到其他值。
例如。当我们尝试将现有值从1.0690000000000000更新为1.0690000000001234时,oracle会自动更改此值1.0690000000001198
这个问题是在我们将数据库升级到12c之后发生的
请指教。
谢谢
巴拉吉N
数字 (32,16) 数据类型列的行为不同,当我们更新这些列时,oracle会自动将值四舍五入到其他值。
例如。当我们尝试将现有值从1.0690000000000000更新为1.0690000000001234时,oracle会自动更改此值1.0690000000001198
这个问题是在我们将数据库升级到12c之后发生的
请指教。
谢谢
巴拉吉N
专家解答
抱歉-我看不到这种行为 (下面是我的测试用例),并且您的livesql测试用例看起来也很好 (即,没有修改该值)
您可以使用类似于我上面的测试用例进行复制吗?
SQL> create table t ( x number(32,16));
Table created.
SQL> insert into t values (1.0690000000000000);
1 row created.
SQL> select * from t;
X
---------------------------
1.0690000000000000
1 row selected.
SQL> update t set x = 1.0690000000001234;
1 row updated.
SQL> select * from t;
X
---------------------------
1.0690000000001234
1 row selected.
您可以使用类似于我上面的测试用例进行复制吗?
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




