無需重新編譯即可動態產生LINQ 查詢
在查詢參數源自動態更新的外部資料的場景中,需要產生LINQ查詢無需重新編譯原始碼。考慮像 SomeObject 這樣具有大量屬性的物件。
透過從資料庫中儲存的 XML 結構中提取條件來動態建立新的 LINQ 查詢是否可行?
例如:
var result = from i in someObj where //XML requests Name = 'Bob'...so append this where clause 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 資料動態產生 LINQ 查詢而無需重新編譯?的詳細內容。更多資訊請關注PHP中文網其他相關文章!