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

编程入门 行业动态 更新时间:2024-10-09 07:26:38

Specified cast is not valid Exception;<a href=https://www.elefans.com/category/jswz/34/1768302.html style=数据类型不一致引起[指定的转化无效]异常"/>

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

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维护数据时有点小问题,导致出现了小数的情况,从而引发这个异常。

更多推荐

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

本文发布于:2024-03-15 00:23:58,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1737695.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:数据类型   异常   cast   valid   Exception

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!