亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

LINQ 條件查詢,其中值可能為空

LINQ 條件查詢,其中值可能為空

C#
嚕嚕噠 2022-08-20 16:07:43
我正在嘗試編寫一個查詢以從數據庫中選擇數據。我有以下代碼: from notes in ctx.Notes .Where(x => x.UserId== user.UserId  || x.UserId == user.FamilyId  || x.UserId == user.CompanyId).DefaultIfEmpty()這樣做的問題是,FamilyId 和 CompanyId 都是可為 null 的類型,可能根本沒有任何損壞整個查詢的值。我該如何重寫它,以便它只查找FamilyId/CompanyId,如果它們具有值?
查看完整描述

2 回答

?
一只甜甜圈

TA貢獻1836條經驗 獲得超5個贊

創建條件查詢:


var users = ctx.Notes.Where(x => x.UserId == user.UserId);


if (user.FamilyId != null)

{

    users = users.Union(ctx.Notes.Where(x => x.UserId == user.FamilyId));

}


if (user.CompanyId != null)

{

    users = users.Union(ctx.Notes.Where(x => x.UserId == user.CompanyId ));

}


var result = users.ToArray();


查看完整回答
反對 回復 2022-08-20
?
瀟瀟雨雨

TA貢獻1833條經驗 獲得超4個贊

很簡單,只需添加一個 AND 子句來檢查它是否不為 null:

 from notes in ctx.Notes.Where(x => x.UserId== user.UserId || (user.FamilyId ! =null && x.UserId == user.FamilyId) || (user.CompanyId !=null && x.UserId == user.CompanyId)).DefaultIfEmpty()


查看完整回答
反對 回復 2022-08-20
  • 2 回答
  • 0 關注
  • 282 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號