1 回答

TA貢獻(xiàn)1818條經(jīng)驗(yàn) 獲得超11個(gè)贊
您的“嘗試動(dòng)態(tài)查詢”有兩個(gè)問(wèn)題:
當(dāng)轉(zhuǎn)換為動(dòng)態(tài)查詢時(shí),您混合了變量名稱,因?yàn)?code>i和
j
太相似。it
是不明確的,因?yàn)橛?2 個(gè) lambda,因此它被解析為最里面 lambda 的參數(shù)。
首先,我們將其重命名i
為p
(“產(chǎn)品名稱”)和j
(s
“搜索”):
var query = names.Where(p => vars.Any(s => p.Contains(s))).ToList();
然后你可以直接將其轉(zhuǎn)換為動(dòng)態(tài) Linq 表達(dá)式:
// The type of vars needs to be IEnumerable<string> otherwise Dynamic Linq does not see .Any
IEnumerable<string> vars = new[] {"i", "a"};
var query2 = names.Where("p => @0.Any(s => p.Contains(s))", vars).ToList();
然后你可以將內(nèi)部 lambda (s) 的參數(shù)替換為it
var query3 = names.Where("p => @0.Any(p.Contains(it))", vars).ToList();
正如您所看到的,您混淆了 的對(duì)象和參數(shù)Contains
。
然后您可以應(yīng)用 EF 查詢的表達(dá)式。所以參數(shù)的用法p
變成p.ProductName
:
IEnumerable<string> vars = new[] {"i", "a"}; query = query.Where("p => @0.Any(p.ProductName.Contains(it))", vars).ToList();
或者像這樣:
IEnumerable<string> vars = new[] {"i", "a"}; query = query.Where("p => @0.Any(s => p.ProductName.Contains(s))", vars).ToList();
- 1 回答
- 0 關(guān)注
- 202 瀏覽
添加回答
舉報(bào)