問題:
我們可以在不更改原始程式碼的情況下動態建構LINQ 查詢嗎?在這種情況下,將從資料庫中儲存的 XML 配置中提取查詢參數。
示例:
var result = from i in someObj where name = 'Bob'
動態查詢生成:
答案:
表達式樹為此動態查詢產生提供了解決方案。以下是一個程式碼範例:
var param = Expression.Parameter(typeof(SomeObject), "p"); var exp = Expression.Lambda<Func<SomeObject, bool>>( Expression.Equal( Expression.Property(param, "Name"), Expression.Constant("Bob") ), param ); var query = someObj.Where(exp);
說明:
注意: 這種方法更複雜,但為需要透過 XML 配置進行動態查詢構造的情況提供了靈活性。
以上是可以從 XML 配置建立動態 LINQ 查詢嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!