强制转换为值类型“System.Double”失败的原因
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,本篇内容主要讲解"强制转换为值类型"System.Double"失败的原因",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"强制转换为值类型"System.D
千家信息网最后更新 2025年02月03日强制转换为值类型“System.Double”失败的原因
本篇内容主要讲解"强制转换为值类型"System.Double"失败的原因",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"强制转换为值类型"System.Double"失败的原因"吧!
foreach (var item in entityList) { ChannelReportDto channelReportDto = new ChannelReportDto(); channelReportDto.Id = item.Id; channelReportDto.YueziCenterId = item.YueziCenterId; channelReportDto.YueziCenterName = item.YueziCenterName; channelReportDto.ChannelName = item.ChannelName; channelReportDto.SumProfitAmount = OrderServiceProjectresult.Where(w => w.ChannelId == item.Id && w.IsDeleted == false).Select(s => s.SumProfitAmount).Sum(); channelReportDto.SettleProfitAmount = OrderServiceProjectresult.Where(w => w.ChannelId == item.Id && w.IsSettlement == true).Select(s => s.SumProfitAmount).Sum(); channelReportDto.NoSettleProfitAmount = OrderServiceProjectresult.Where(w => w.ChannelId == item.Id && w.IsSettlement == false).Select(s => s.SumProfitAmount).Sum(); list.Add(channelReportDto); }
这样写的时候 就报了这个错 The cast to value type 'System.Double' failed because the materialized value is null. Either the result type's generic parameter or the query must use a nullable type.
主要原因是没有适合查询条件的行 去计算,
所以改成以下写法就OK
foreach (var item in entityList) { ChannelReportDto channelReportDto = new ChannelReportDto(); channelReportDto.Id = item.Id; channelReportDto.YueziCenterId = item.YueziCenterId; channelReportDto.YueziCenterName = item.YueziCenterName; channelReportDto.ChannelName = item.ChannelName; channelReportDto.SumProfitAmount = OrderServiceProjectresult.Where(w => w.ChannelId == item.Id && w.IsDeleted == false).Sum(s =>(double?)s.SumProfitAmount)??0.00; channelReportDto.SettleProfitAmount = OrderServiceProjectresult.Where(w => w.ChannelId == item.Id && w.IsSettlement == true).Sum(s => (double?)s.SumProfitAmount) ?? 0.00; channelReportDto.NoSettleProfitAmount = OrderServiceProjectresult.Where(w => w.ChannelId == item.Id && w.IsSettlement == false).Sum(s => (double?)s.SumProfitAmount) ?? 0.00; list.Add(channelReportDto); }
到此,相信大家对"强制转换为值类型"System.Double"失败的原因"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
原因
类型
强制
内容
学习
查询
实用
更深
兴趣
写法
实用性
实际
操作简单
方法
时候
更多
朋友
条件
网站
频道
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
农村小学网络安全教育
ncbi gtr数据库
榆林网络技术质量
视频监控软件开发合同范本
天翼服务器怎么注销
沧州九星互联网科技
永康市网络安全执法
筋斗鱼软件开发有限公司招聘
android 云服务器
网络安全公司的待遇
战66服务器
戴尔740服务器声音很大
白云区数据网络技术开发工艺
软件开发工作个人简历
租服务器如何防护
原神都分什么服务器
大数据技术和计算机网络技术
微电子软件开发项目
软件开发 云笔记本
靠谱的erp财务软件开发企业
seer数据库脚本
网络安全威胁就在身边
云终端如何连接到服务器
搞软件开发能和大数据接轨吗
杭州优码网络技术
软件开发工作量认定纠纷案
应急部网络安全
河北教育技术软件开发
计算机网络技术专升本分数
实时同步数据库数据的方法