c# – 如果Linq的字段为空,如何替换值?
发布时间:2020-12-16 00:19:18 所属栏目:百科 来源:网络整理
导读:我有以下报告: var menuItems = _menuRepository.GetPk(pk) .Where(m = m.Status == "00") .OrderBy(m = m.Order) .Select(m = new MenuItem { PartitionKey = m.PartitionKey,RowKey = m.RowKey,Order = m.Order,Order1 = m.Order.Substring(0,1),Order2 =
我有以下报告:
var menuItems = _menuRepository.GetPk(pk) .Where(m => m.Status == "00") .OrderBy(m => m.Order) .Select(m => new MenuItem { PartitionKey = m.PartitionKey,RowKey = m.RowKey,Order = m.Order,Order1 = m.Order.Substring(0,1),Order2 = m.Order.Substring(2,Order3 = m.Order.Substring(4,Order4 = m.Order.Substring(6,2),Title = m.Title,Type = m.Type,Link = m.Link,TextLength = m.TextLength }); 如果存在Order为null或空的记录,则会失败.有没有办法,如果m.Order为null或为空,我可以替换8个零的字符串,并为所有Order.Substrings替换一个零? 解决方法
您可以使用
null-coalescing运算符:
var menuItems = _menuRepository.GetPk(pk) .Where(m => m.Status == "00") .OrderBy(m => m.Order) .Select(m => { var orderOrEmpty = m.Order ?? "00000000"; return new MenuItem { PartitionKey = m.PartitionKey,Order1 = orderOrEmpty.Substring(0,Order2 = orderOrEmpty.Substring(2,Order3 = orderOrEmpty.Substring(4,Order4 = orderOrEmpty.Substring(6,TextLength = m.TextLength }; }); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |