首頁 後端開發 C++ 如何使用 Lambda/LINQ 在清單中有效率地搜尋多個關鍵字?

如何使用 Lambda/LINQ 在清單中有效率地搜尋多個關鍵字?

Jan 21, 2025 am 11:56 AM

How to Efficiently Search for Multiple Keywords in a List Using Lambda/LINQ?

Lambda/LINQ結合Contains條件進行多關鍵字搜尋

在許多資料庫操作中,經常需要在文字欄位中搜尋特定的關鍵字。這通常涉及在SQL中使用LIKE運算符,例如:

SELECT * FROM MainList
WHERE Comment LIKE '%keyword1%'
OR Comment LIKE '%keyword2%'
登入後複製

此查詢分別搜尋每個關鍵字,導致一個包含多個LIKE子句的複雜查詢。要在C#中使用Lambda/LINQ執行類似的搜索,需要考慮以下場景:

已知條件:

  • MainList:包含Comments欄位的清單
  • keywords:要搜尋的關鍵字清單

預期結果:

  • 一個新列表,包含MainList中Comments字段包含keywords列表中任意關鍵字的記錄。

解決方案利用一個名為FilterByItems的擴充方法:

var newList = MainList
   .FilterByItems(keywords, (m, k) => m.Comments.Contains(k), true)
   .ToList();
登入後複製

FilterByItems方法接受以下參數:

  • items:要搜尋的關鍵字清單
  • filterPattern:一個表達式,用來檢查記錄是否包含特定關鍵字
  • isOr:一個標誌,指示是使用OR還是AND運算子組合謂詞(預設為OR)

此方法實作以items清單中的每個關鍵字取代filterPattern表達式中的佔位符參數。然後,產生的謂詞用來過濾MainList。

ExpressionReplacer類別處理謂詞中的參數替換。它用實際的關鍵字值取代佔位符參數。

這種方法允許有效率地在一個查詢中搜尋多個關鍵字,減少了對多個LIKE子句的需求,並簡化了SQL語句。

以上是如何使用 Lambda/LINQ 在清單中有效率地搜尋多個關鍵字?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Gulc:從頭開始建造的C庫 Gulc:從頭開始建造的C庫 Mar 03, 2025 pm 05:46 PM

Gulc:從頭開始建造的C庫

c語言函數返回值的類型有哪些?返回值是由什麼決定的? c語言函數返回值的類型有哪些?返回值是由什麼決定的? Mar 03, 2025 pm 05:52 PM

c語言函數返回值的類型有哪些?返回值是由什麼決定的?

c語言函數格式字母大小寫轉換步驟 c語言函數格式字母大小寫轉換步驟 Mar 03, 2025 pm 05:53 PM

c語言函數格式字母大小寫轉換步驟

c語言函數的定義和調用規則是什麼 c語言函數的定義和調用規則是什麼 Mar 03, 2025 pm 05:53 PM

c語言函數的定義和調用規則是什麼

distinct用法和短語分享 distinct用法和短語分享 Mar 03, 2025 pm 05:51 PM

distinct用法和短語分享

c語言函數返回值在內存保存在哪裡? c語言函數返回值在內存保存在哪裡? Mar 03, 2025 pm 05:51 PM

c語言函數返回值在內存保存在哪裡?

C標準模板庫(STL)如何工作? C標準模板庫(STL)如何工作? Mar 12, 2025 pm 04:50 PM

C標準模板庫(STL)如何工作?

如何有效地使用STL(排序,查找,轉換等)的算法? 如何有效地使用STL(排序,查找,轉換等)的算法? Mar 12, 2025 pm 04:52 PM

如何有效地使用STL(排序,查找,轉換等)的算法?

See all articles