如何使用 Lambda/LINQ 在清單中有效率地搜尋多個關鍵字?
Jan 21, 2025 am 11:56 AMLambda/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 DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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