国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

自定義LINQ表達式支持,(內有植入廣告,請自行過濾)

2019-11-17 03:49:12
字體:
來源:轉載
供稿:網友
  好吧,我就招了吧,我是打算發個廣告來著,可又一想,發個純廣告帖上來,肯定罵聲一片,磚頭、雞蛋滿天飛,道不如把DAC中,關于自定義LINQ表達式支持的代碼講解一下,或許對一些自己寫數據層或者想寫些LINQ擴展實用的人會有些幫助,就算沒什么幫助,那就起到點兒“拋磚引玉”的作用,豈不是也很好!
在DAC的之前版本中,使用如下表達式進行查詢:

IEnumerable<Issue> q = this.dc.Query<Issue>(Issue._.IssueID >= 0);

這個“可愛”的”_”顯得是那樣的“不成熟”,特別是在這個LINQ橫行的時代,顯得特不“與時俱進”。于是就有了對DAC擴展LINQ支持的v2.6版。

var q = this.dc.Query<Issue>(s => s.IssueID > 0);



var q = from s in (this.dc.GetQueryableData<Issue>())

where s.IssueID > 0

select s;

上面的兩種方法的實現,主要是靠對表達式的解析,組裝SQL語句。老趙的帖子寫的很好,也可以看DAC的源碼(我是植入廣告)。

      我今天主要想說的是,如果我們原來有自已的表達式樹及其解析功能,那能不能讓它很容易的“升級”到LINQ的支持呢?!是的,很容易!

            var q = from s in SystemUser._

                    where s.FullName == s.FullName.Max

                    orderby s.UserID

                    select s.Except(s.PassWord);

要相讓一個對象可以被”where”, “orderby”, “select”,那就讓它實現名為”Where”, “OrderBy”, “Select”的方法,或使用Extension Method方式,就象DAC中:

    public static class QueryExPRessionExtension

    {

        public static RaisingStudio.Data.Expressions.IQueryExpression<T> Where<T>(

          this RaisingStudio.Data.Expressions.IQueryExpression<T> source,

          Expression<Func<T, RaisingStudio.Data.Expressions.ConditionExpression>> predicate)

        {

            return (new RaisingStudio.Data.Expressions.QueryExpression<T>(

              source.Value,

              source.Table,

              (predicate.Compile())(source.Value),

              source.Columns));

        }



        public static RaisingStudio.Data.Expressions.IQueryExpression<T> OrderBy<T>(

        this RaisingStudio.Data.Expressions.IQueryExpression<T> source,

        Expression<Func<T, RaisingStudio.Data.Expressions.ColumnExpression>> predicate)

        { … }



        public static RaisingStudio.Data.Expressions.IQueryExpression<T> Select<T>(

        this RaisingStudio.Data.Expressions.IQueryExpression<T> source,

        Expression<Func<T, object>> predicate)

        { ... }

}



在方法的實現中,對傳入的“系統”表達式,進行Compile方法調用,即可返回“自定義”的表達式,然后將這些“自定義”的表達式保存在“查詢表達式(QueryExpression)”中,當“查詢”被執行時,就可以直接取出保存下來的“自定義”表達式,這樣,再利用上代碼原來對“自定義”表達式的解析,就可以實現查詢了!!!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 金沙县| 从江县| 定南县| 江津市| 高邮市| 尼玛县| 通海县| 洛川县| 望江县| 湘潭市| 阳东县| 云阳县| 桑日县| 台前县| 枞阳县| 清水县| 腾冲县| 合川市| 玛曲县| 鲁山县| 临城县| 宜阳县| 景东| 宁乡县| 和林格尔县| 惠来县| 尤溪县| 宁阳县| 屯昌县| 师宗县| 家居| 元江| 柞水县| 南漳县| 龙岩市| 永登县| 鄯善县| 健康| 定西市| 襄汾县| 汨罗市|