我正在开发一个从C#数据库中提取数据的Oracle程序。我安装了ODAC (刚刚更新到版本12.2c),连接到12.1Oracle数据库并在我的项目中引用Oracle.DataAccess
在我的一个查询中,我想使用众所周知的"hack“exp(sum(ln(Col)将一些值相乘。但是,当我通过ODAC连接数据库时,似乎不支持ln函数。我收到一条错误消息,提示“角色无效”。同样的查询在Oracle SQL Developer中也能完美地工作。
像这样简单的东西:
select ln(value) from table where id=1将会失败,而
select sum(value) from table where id=1工作得很好。难道在ODAC中根本不支持ln-function吗?我需要添加另一个引用吗?如果没有,我如何让它在.NET程序中工作?IDE是VS2015。
发布于 2017-10-18 14:30:58
事实证明,这只是一个相当误导人的错误消息。根本问题是从高精度Oracle数字到.NET小数的转换。所以使用TRUNC(exp(sum(ln(Col)),12)解决了这个问题。
https://stackoverflow.com/questions/46798711
复制相似问题