EFCore报错:System.Data.SqlTypes.SqlNullValueException:“Data is Null. This method or property cannot be

文章讲述了在使用EntityFrameworkCore(EFCore)进行Linq查询时遇到的Null异常问题,作者提到在处理可能存在空值的数据库数据时,应加入`DefaultIfEmpty()`方法,以确保查询结果始终包含默认值,即使无匹配项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.首先使用确保Linq查询是没有问题的,我的查询为:

var query = from menu in Context.Set<MenuInfo>()
            join role_menu in Context.Set<RoleMenu>()
            on menu.MenuId equals role_menu.MenuId
            where roles.Contains(role_menu.RoleId) && menu.State == 1
            select menu;

var tmp = query.Distinct().ToList();

 

2、这里tmp的数据类型是:List<MenuInfo>

 

3、这样执行后发现tmp那一行报错,查了很久发现是数据库中的某些数据是Null,如果确定数据库中想要保存的数据是空值的话那就在Linq转换为List集合前加上:DefaultIfEmpty()。通过调用DefaultIfEmpty()方法,即使查询结果为空,它也会返回一个包含默认值Null的元素

变为:

var tmp = query.DefaultIfEmpty().Distinct().ToList();

 

 

备注:在旧版本的EFCore中可能最开始的写法就是正确的,不需要加上DefaultIfEmpty()就能正确运行

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值