Specified cast is not valid Exception;数据类型不一致引起[指定的转化无效]异常

3 篇文章 0 订阅
1 篇文章 0 订阅

Specified cast is not valid Exception

指定的转化无效 异常。 记录一下遇到的异常。

背景环境:

  • Dotnet.Core 3.1
  • C#
  • Oracle DB,测试时QAS DB正常;PRD DB抛出异常。

异常信息:

Message[string]:"Specified cast is not valid."
Source [string]:"Oracle.ManagedDataAccess"
"在 Oracle.ManagedDataAccess.Client.OracleDataReader.GetDecimal(Int32 i)\r\n   
在 Oracle.ManagedDataAccess.Client.OracleDataReader.GetValue(Int32 i)\r\n   
在 Oracle.ManagedDataAccess.Client.OracleDataReader.GetValues(Object[] values)\r\n   
在 System.Data.ProviderBase.DataReaderContainer.CommonLanguageSubsetDataReader.GetValues(Object[] values)\r\n   
在 System.Data.ProviderBase.SchemaMapping.LoadDataRow()\r\n   
在 System.Data.Common.DataAdapter.FillLoadDataRow(SchemaMapping mapping)\r\n   
在 System.Data.Common.DataAdapter.FillFromReader(DataSet dataset, DataTable datatable, String srcTable, DataReaderContainer dataReader, Int32 startRecord, Int32 maxRecords, DataColumn parentChapterColumn, Object parentChapterValue)\r\n   
在 System.Data.Common.DataAdapter.Fill(DataTable[] dataTables, IDataReader dataReader, Int32 startRecord, Int32 maxRecords)\r\n   
在 Oracle.ManagedDataAccess.Client.OracleDataAdapter.Fill(DataTable[] dataTables, Int32 startRecord, Int32 maxRecords, IDbCommand command, CommandBehavior behavior)\r\n   
在 System.Data.Common.DbDataAdapter.Fill(DataTable dataTable)\r\n   
在 XXX_api.XXXX.XXXX.<>c__DisplayClass2_1.<GetXXXTableAsync>b__0() 在 E:\\XXXapi\\XXXX\\XXXXX.cs 中:62 行"

问题定位:

执行SQL(或者Linq to SQL)时,引起的指定的转化无效 异常。
出现以上异常,通常是因为Model文件中相关表的字段数据类型和数据库对应表的字段类型不一致引起的。

解决思路

  • 因为QAS 与PRD 的Oracle DB 版本不一样,一开始还以为是Oracle DB版本的问题,或者是两个DB中表结构(字段)有差异。–然而不是的。
  • 检查model的属性数据类型是否和数据库的一致(尤其是外键关联的表的Model);
  • 最后检查发现,在Model中一个字段定义的是Int类型,对应SQL查询DB中的两个数相除的结果:单位数量PerQty = TotalQty/Qty. 业务逻辑上是一个整数,不会出现小数。但是DB维护数据时有点小问题,导致出现了小数的情况,从而引发这个异常。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
问题的原因是在代码中进行了无效的强制类型转换。这种异常通常发生在对数据库中的数据进行操作时,因为数据库的特殊性,我们可能无法确定获取的数据的实际类型。在这种情况下,如果我们尝试将获取的数据强制转换为错误的类型,就会出现"specified cast is not valid"的异常。为了解决这个问题,我们可以采取以下最佳方法: 1. 确认数据库中该数据的存储类型,确保我们进行正确的类型转换。 2. 对于一些数值类的数据,可以先将其转换为字符串类型,然后再使用适当的方法(如float.Parse()或Convert.ToDouble())进行二次处理。这样可以避免无效的强制类型转换导致的异常。\[3\] 所以,要解决"specified cast is not valid"的异常,我们需要确保进行正确的类型转换,并根据实际情况选择适当的方法来处理数据。 #### 引用[.reference_title] - *1* [Specified cast is not valid ,强制转换失败解决方案](https://blog.csdn.net/u011644138/article/details/106006732)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [【解决】InvalidCastException: Specified cast is not valid.](https://blog.csdn.net/qq_51026638/article/details/127421861)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值