oracle查询无效的object,System.Exception: 指定的转换无效 OracleDataAccess.GenerateDal.MakeMapToObject...

报错:

System.Exception: 指定的转换无效 OracleDataAccess.GenerateDal.MakeMapToObject

微软 c# .net web API 项目

是用sqlconfig里面直接写sql查询语句的简单粗暴方式

然而有一个oracle

sql查询结果

其中有个字段,是计算某列的平均值,

随着新增记录越来越多,平均值的小数点数越来越多,最后达到了小数点后30多位

而数据库里的model用的是decimal类型

所以之前api没有报错,随着新增记录增长,api忽然报错,因为decimal无法

容纳这么多小数点。

调试过程

网上查了一下这个错误,回答大多是

“ 数据库查询结果的字段类型 , 和代码里数据块模型定义的类型 不一致”

然而我看了下,这两个类型,都是数值类型,代码里用的是decimal,数据库查询结果是小数

1. 把字段改了几种其它类型试了下,还是转换错误。“System.Exception: 指定的转换无效 ”

2. 去掉别的字段,只留这一个字段。也是报错。

备注:

期间打开了vs2019的debug模式,加断点,事后证明这个非常有用,可以省去很多瞎猜测瞎摸索的时间精力。

解决方法:

在sql查询语句里,用一个round函数,取小数点后几位例如3位,就解决了。

ROUND() 函数

ROUND 函数用于把数值字段舍入为指定的小数位数。

SQL ROUND() 语法

SELECT ROUND(column_name,decimals) FROM table_name

当然这只是个例,如果您遇上同样的报错,可以参考,却不一定是同类root cause

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值