欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Linq聯(lián)合查詢表結(jié)果集的返回怎么實現(xiàn)

本篇內(nèi)容介紹了“Linq聯(lián)合查詢表結(jié)果集的返回怎么實現(xiàn)”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)公司專注于企業(yè)網(wǎng)絡(luò)營銷推廣、網(wǎng)站重做改版、撫寧網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5網(wǎng)站設(shè)計、商城開發(fā)、集團公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)公司、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為撫寧等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

首先,我們先來了解一些Linq聯(lián)合查詢的知識點。

1.匿名類型的傳遞

static void Main(string[] args)   {   var User = GetAnonymous().Cast(new { UserName = "", LastLoginIp = "" });              Console.Write(User.UserName);       }         static object GetAnonymous()     {     var User = new { UserName = "yaosansi", LastLoginIp = "127.0.0.1" };               return User;     }

當我們定義一個匿名類型,只能通過object類型傳遞,傳遞后編譯器將無法獲悉匿名類型的實際類型。

這行可以通過Cast擴展方法來進行強制轉(zhuǎn)換。以下是Cast方法的原型。

public static T Cast(this object o, T t)       {               return ();         }

2.Linq聯(lián)合查詢之如何生成匿名類型的List?       

var User = GetAnonymous().Cast(new { UserName = "", LastLoginIp = "" });         var list = new List();

原理和上面一致。

var User = new   {        UserName = "yaosansi", LastLoginIp = "127.0.0.1" };              var list = User.MakeList();          list.Add(User);            Console.Write(list[0].UserName);

我們再來看看MakeList()方法:

public static List MakeList(this T t)          {                 return new List();      }

當然,你可能想到上面的方法還不夠***,需要在List中Add一個User,于是有了下面的方法:      

public static List MakeList(this T t,params T[] items)         {               return new List(items);    }

這時調(diào)用的時候可以寫成:

var User = new   {     UserName = "yaosansi", LastLoginIp = "127.0.0.1"   };              var list = User.MakeList(User);          Console.Write(list[0].UserName);

這回我們切入正題,來了解一下Linq聯(lián)合查詢是怎樣實現(xiàn)的。

var q =    from p in db.Products      where p.Supplier.Country == "USA" && p.UnitsInStock == 0    select p;

以上的查詢是兩個有關(guān)系的表,并且返回的只是一個表的內(nèi)容,這種情況下可以在數(shù)據(jù)層中返回強類型的List。如:

public List SelectProducts()   {      var q = from p in db.Products            where p.Supplier.Country == "USA" && p.UnitsInStock == 0               select p;               return q.ToList;   }

如果返回的結(jié)果集是兩個以上表的時候,那該如何傳遞呢? 聰明的你一定想到了,如果返回的是單行數(shù)據(jù)的結(jié)果集就可以我們前面提到的使用匿名類型的傳遞得到我們需要的結(jié)果. public object

public object SelectProducts()  {      var q = from p in db.Products             where p.Supplier.Country == "USA" && p.UnitsInStock == 0               select new {p.UnitsInStock,p.Supplier.Sid};      var result = q.Single();         return result;   }

但這個前提是業(yè)務(wù)邏輯層需要知道數(shù)據(jù)層的匿名類型中的具體類型。這樣分層的意義也就不大了。這并不是我們想要的。而且返回多行數(shù)據(jù)的結(jié)果集時用 匿名的List類型 的方法經(jīng)實驗也失敗了。

方法一:Linq聯(lián)合查詢自定義與返回類型相同結(jié)構(gòu)的類

public class CustomQuery       {  public uint UnitsInStock      { get; set; }               public int Sid      { get; set; }        }

這樣在查詢結(jié)果為多個表的結(jié)果集時,就可以解決了。由于需要知道返回的匿名類型,除了不符合多層以外,還需要額外定義一個類。但這樣確時可以使用強類型返回我們所需要的結(jié)果。

方法二:Linq聯(lián)合查詢使用System.Func委托 (參考:Returning var from a method in C# 3.0)

數(shù)據(jù)層:

public IEnumerable GetCustomersWithOrders(Func<Customer, IEnumerable, TProjection> projection)   {    return from customer in _customers                let customerOrders = from  order in _orders                                     where order.CustomerID = customer.ID                  select projection(customer, customerOrders);  }

業(yè)務(wù)邏輯層:

var results = GetCustomersWithOrders(  (customer, orders) => new   {    Name = customer.Name,                    OrderCount = orders.Count()        });

這樣返回的結(jié)果在業(yè)務(wù)邏輯層里仍然是真正的匿名類型,可以直接使用了。

“Linq聯(lián)合查詢表結(jié)果集的返回怎么實現(xiàn)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

文章題目:Linq聯(lián)合查詢表結(jié)果集的返回怎么實現(xiàn)
URL網(wǎng)址:http://aaarwkj.com/article30/gjospo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、電子商務(wù)App設(shè)計、網(wǎng)站導航、品牌網(wǎng)站制作、營銷型網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
久久99热这里只频精品| 日韩av一区二区三区在线| 99热这里只有精品免费播放| 亚洲理论电影在线观看| 亚洲国产一区二区高清| 亚洲欧美午夜福利视频| 日本不卡二区高清三区| 日韩二区三区在线视频| 亚洲国产欧美在线人成人| 白嫩少妇情久久密月久久| 人妇乱系列中文字幕人妻| 国产精品成人亚洲一区二区| 国产自拍在线视频精品| 91一区二区亚洲嫩草| 久久99精品人妻一区二区三区| 关于男女性生活的视频| 精品亚洲欧美日韩国产| 亚洲视频免费在线一区| 成人黄片在线免费播放| 国产手机在线91精品观看| 91九色国产在线播放| 天天操天天射夜夜撸| 欧美福利免费在线视频| 亚洲人妻av一区二区三区| 又黄又爽区一区二区三| 中文字幕乱码熟女人妻视频| 密臀av一区二区三区| 精品蜜桃臀91人少妇| 粉嫩av蜜臀一区二区三区| 日本一区二区电影大全| 狠狠综爱五月天的婷婷| 欧美日韩国产激情另类| 日韩欧美精品视频一区| 精品久久亚洲一区二区欧美| 欧美亚洲另类在线日韩国产| 日韩欧美精品在线观看免费| 国模一区二区三区视频| 午夜性色福利在线播放| 中文字幕乱码亚洲中文在线| 国产欧美日本一区二区| 精品成人乱色一区二区|