Nullable object must have a value


有一個linq查詢,由inner join改成left join, 對於有空值,就會出現Nullable object must have a value 的錯誤.

原來的查詢:

 var qry =
            from c in _context.CCC
            join f in _context.FFF .Where(t=>t.IsActive==true)
            on  new { c.ProjectId, cat = c.Category } equals new { f.ProjectId, cat = f.Category }
            where  c.IsActive == true 
            select
            new
            {
                c.Id,
                f.category
         }

 

left join, select的字段做null判斷

 var qry =
            from c in _context.CCC
            join f in _context.FFF .Where(t=>t.IsActive==true)
            on  new { c.ProjectId, cat = c.Category } equals new { f.ProjectId, cat = f.Category }
            into temp from tt in temp.DefaultIfEmpty()
            where  c.IsActive == true 
            select
            new
            {
                c.Id,
                category=(f==null)?'':f.category
         }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM