加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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
                                };
                });

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读