linq to entity DistinctBy && DefaultIfEmpty


根據某屬性去重

使用第三方庫:MoreLINQ

Install-Package morelinq -Version 3.0.0
data.DistinctBy(x=>x.Id)

實現left join

使用DefaultIfEmpty(),是left join
沒有DefaultIfEmpty(),是inner join

var query2 = (
    from users in Repo.T_Benutzer
    from mappings in Repo.T_Benutzer_Benutzergruppen
        .Where(mapping => mapping.BEBG_BE == users.BE_ID).DefaultIfEmpty()
    from groups in Repo.T_Benutzergruppen
        .Where(gruppe => gruppe.ID == mappings.BEBG_BG).DefaultIfEmpty()
    select new
    {
         UserId = users.BE_ID
        ,UserName = users.BE_User
        ,UserGroupId = mappings.BEBG_BG
        ,GroupName = groups.Name
    }
);

參考資料

LEFT JOIN in LINQ to entities?


免責聲明!

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



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