开发者

Using LINQ to perform a left outer join

I'm trying to build a list that contains all the objects from one list but updates a specific property if the object exists in another list.

Firstly I create a List of all the possible "Options". I then want to update the "Selected" property of any items in this list that also exist in another list of "Options" that I have created. I was hoping the code below would work but I'm getting the exception "Object reference not set to an instance of an object".

   开发者_开发问答     var query = from o in AllOptions
                    join so in SelectedOptions on o.Code equals so.Code into newOptions
                    from no in newOptions.DefaultIfEmpty()
                    select new Option
        {
            Name = o.Name,
            Description = o.Description,
            Code = o.Code,
            Applicable = o.Applicable,
            Selected = no.Selected
        };


You're getting the exception from the no.Selected statement in your projection, when no is null it will throw because you're dereferencing a null.

You can fix it by specifying a default value when no is null:

//default to false when no is null
Selected = (no == null) ? false : no.Selected
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜