in寫法:
arraydictype:int陣列
db.getquery().where(a => arraydictype.contains(a.dictype)).tolist();
person1: id=1, name=
"test1"
person2: id=1, name=
"test1"
person3: id=2, name=
"test2"
以上list如果直接使用distinct方法進行過濾,仍然返回3條資料,而需要的結果是2條資料。下面給出解這個問題的方法:
方法1:
distinct
方法中使用的相等比較器。這個比較器需要重寫equals和gethashcode方法,個人不推薦,感覺較麻煩,需要些多餘的類,並且用起來還要例項化乙個比較器,當然自己也可以寫乙個泛型的比較器生成工廠用來專門生成比較器,但仍然覺得較麻煩。
msdn給出的做法,具體參照:
方法2:
自己擴充套件乙個distinctby。這個擴充套件方法還是很不錯的,用起來很簡潔,適合為框架新增的distinct擴充套件方法。
public
static
ienumerabledistinctby(
this
ienumerablesource, funckeyselector)
}
}
使用方法如下(針對id,和name進行distinct):
var
query = people.distinctby(p =>
new
);
若僅僅針對id進行distinct:
var
query = people.distinctby(p => p.id);
方法3:通過groupby分組後,並取出第一條資料。簡單易用,很方便。這是一種迂迴策略,**理解起來沒有distinct表意清晰,雖然實現了效果。
listdistinctpeople = allpeople
.groupby(p =>
new
)
.select(g => g.first())
.tolist();
LINQ優化 將GroupBy換做Distinct
這樣做也是沒有辦法的,我之前專案中,查詢中這樣寫的分組 1 form t in db.table 2where t.state true 3 group t by new 4 9 into p 10select new 導致的就是,資料表中不到1w行資料,經過分組後是752行,但是第一次查詢要將近1...
Linq條件累加查詢
public iqueryablegetallespechotelinfo string position,datetime?starttime,datetime?deptime,string rprice,string commerical,string districtname,string k...
動態拼接LINQ查詢條件
在實際開發過程中,expression查詢的條件總是多樣的,新建乙個擴充套件類支援動態拼接條件。public static class predicateextensions 機關函式應用false時 單個and無效,多個and無效 單個or有效,多個or有效 混應時寫在or後面的and有效。即,設...