第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

動(dòng)態(tài) Linq 包含多個(gè)值

動(dòng)態(tài) Linq 包含多個(gè)值

如何在 Dynamic Linq 中將多個(gè)值與 Contain 一起使用。正常 Linq 的預(yù)期:using System;using System.Linq;public class Simple {  public static void Main() {    string[] names = { "Burke", "Laptop", "Computer",                        "Mobile", "Ahemed", "Sania",                        "Kungada", "David","United","Sinshia" };      string[] vars = {"i","a"};      var query = names.Where(i=> vars.Any(j=>i.Contains(j))).ToList();      Console.WriteLine(query.Count);  }}預(yù)期 SQLSELECT * FROM User WHERE (NAME LIKE '%a%'OR NAME LIKE '%b%')嘗試過(guò)動(dòng)態(tài) Linq :query = query.Where("new[]{\"a\",\"c\"}.Any(i=>i.Contains(it.ProductName))");返回異常:No property or field 'ProductName' exists in type 'String'依賴項(xiàng):.NET核心2.2實(shí)體框架核心 2.2.6System.Linq.Dynamic.Core 1.0.18 ( https://github.com/StefH/System.Linq.Dynamic.Core )
查看完整描述

1 回答

?
慕尼黑8549860

TA貢獻(xiàn)1818條經(jīng)驗(yàn) 獲得超11個(gè)贊

您的“嘗試動(dòng)態(tài)查詢”有兩個(gè)問(wèn)題:

  1. 當(dāng)轉(zhuǎn)換為動(dòng)態(tài)查詢時(shí),您混合了變量名稱,因?yàn)?code>i和j太相似。

  2. it是不明確的,因?yàn)橛?2 個(gè) lambda,因此它被解析為最里面 lambda 的參數(shù)。

首先,我們將其重命名ip(“產(chǎn)品名稱”)和js“搜索”):

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();


查看完整回答
反對(duì) 回復(fù) 2023-09-16
  • 1 回答
  • 0 關(guān)注
  • 202 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)