新聞中心
LINQ動(dòng)態(tài)查詢不是很容易就實(shí)現(xiàn)的,但是一旦能夠熟練運(yùn)用了,那LINQ動(dòng)態(tài)查詢能起很大作用,本文筆者就來(lái)向你介紹一下LINQ動(dòng)態(tài)查詢。

成都創(chuàng)新互聯(lián)公司-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比岷縣網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式岷縣網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋岷縣地區(qū)。費(fèi)用合理售后完善,十余年實(shí)體公司更值得信賴。
本文介紹LINQ的高級(jí)特性,其包括大家都關(guān)心的LINQ動(dòng)態(tài)查詢的用法,另外簡(jiǎn)單提下ID標(biāo)識(shí)這個(gè)知識(shí)。
LINQ動(dòng)態(tài)查詢有這樣一個(gè)場(chǎng)景:應(yīng)用程序可能會(huì)提供一個(gè)用戶界面,用戶可以使用該用戶界面指定一個(gè)或多個(gè)謂詞來(lái)篩選數(shù)據(jù)。這種情況在編譯時(shí)不知道查詢的細(xì)節(jié),LINQ動(dòng)態(tài)查詢將十分有用。
在LINQ中,Lambda表達(dá)式是許多標(biāo)準(zhǔn)查詢運(yùn)算符的基礎(chǔ),編譯器創(chuàng)建lambda表達(dá)式以捕獲基礎(chǔ)查詢方法(例如 Where、Select、Order By、Take While 以及其他方法)中定義的計(jì)算。表達(dá)式目錄樹(shù)用于針對(duì)數(shù)據(jù)源的結(jié)構(gòu)化查詢,這些數(shù)據(jù)源實(shí)現(xiàn)IQueryable 。
例如,LINQ to SQL 提供程序?qū)崿F(xiàn) IQueryable 接口,用于查詢關(guān)系數(shù)據(jù)存儲(chǔ)。C#和Visual Basic編譯器會(huì)針對(duì)此類(lèi)數(shù)據(jù)源的查詢編譯為代碼,該代碼在運(yùn)行時(shí)將生成一個(gè)表達(dá)式目錄樹(shù)。然后,查詢提供程序可以遍歷表達(dá)式目錄樹(shù)數(shù)據(jù)結(jié)構(gòu),并將其轉(zhuǎn)換為適合于數(shù)據(jù)源的查詢語(yǔ)言。
表達(dá)式目錄樹(shù)在LINQ中用于表示分配給類(lèi)型為Expression 的變量的Lambda表達(dá)式。還可用于創(chuàng)建動(dòng)態(tài)LINQ查詢。
System.Linq.Expressions命名空間提供用于手動(dòng)生成表達(dá)式目錄樹(shù)的API。Expression類(lèi)包含創(chuàng)建特定類(lèi)型的表達(dá)式目錄樹(shù)節(jié)點(diǎn)的靜態(tài)工廠方法,例如,ParameterExpression(表示一個(gè)已命名的參數(shù)表達(dá)式)或 MethodCallExpression(表示一個(gè)方法調(diào)用)。
編譯器生成的表達(dá)式目錄樹(shù)的根始終在類(lèi)型Expression 的節(jié)點(diǎn)中,其中TDelegate是包含至多五個(gè)輸入?yún)?shù)的任何TDelegate委托;也就是說(shuō),其根節(jié)點(diǎn)是表示一個(gè)lambda表達(dá)式。
下面幾個(gè)例子描述如何使用表達(dá)式目錄樹(shù)來(lái)創(chuàng)建動(dòng)態(tài)LINQ查詢。
1.LINQ動(dòng)態(tài)查詢之Select
下面例子說(shuō)明如何使用表達(dá)式樹(shù)依據(jù) IQueryable 數(shù)據(jù)源構(gòu)造一個(gè)動(dòng)態(tài)查詢,查詢出每個(gè)顧客的ContactName,并用GetCommand方法獲取其生成SQL語(yǔ)句。
- //依據(jù)IQueryable數(shù)據(jù)源構(gòu)造一個(gè)查詢
- IQueryable
custs = db.Customers; - //組建一個(gè)表達(dá)式樹(shù)來(lái)創(chuàng)建一個(gè)參數(shù)
- ParameterExpression param =
- Expression.Parameter(typeof(Customer), "c");
- //組建表達(dá)式樹(shù):c.ContactName
- Expression selector = Expression.Property(param,
- typeof(Customer).GetProperty("ContactName"));
- Expression pred = Expression.Lambda(selector, param);
- //組建表達(dá)式樹(shù):Select(c=>c.ContactName)
- Expression expr = Expression.Call(typeof(Queryable), "Select",
- new Type[] { typeof(Customer), typeof(string) },
- Expression.Constant(custs), pred);
- //使用表達(dá)式樹(shù)來(lái)生成動(dòng)態(tài)查詢
- IQueryable
query = db.Customers.AsQueryable() - .Provider.CreateQuery
(expr); - //使用GetCommand方法獲取SQL語(yǔ)句
- System.Data.Common.DbCommand cmd = db.GetCommand(query);
- Console.WriteLine(cmd.CommandText);
生成的SQL語(yǔ)句為:
- SELECT [t0].[ContactName] FROM [dbo].[Customers] AS [t0]
2.LINQ動(dòng)態(tài)查詢之Where
下面一個(gè)例子是“搭建”Where用法來(lái)動(dòng)態(tài)查詢城市在倫敦的顧客。
- IQueryable
custs = db.Customers; - //創(chuàng)建一個(gè)參數(shù)c
- ParameterExpression param =
- Expression.Parameter(typeof(Customer), "c");
- //c.City=="London"
- Expression left = Expression.Property(param,
- typeof(Customer).GetProperty("City"));
- Expression right = Expression.Constant("London");
- Expression filter = Expression.Equal(left, right);
- Expression pred = Expression.Lambda(filter, param);
- //Where(c=>c.City=="London")
- Expression expr = Expression.Call(typeof(Queryable), "Where",
- new Type[] { typeof(Customer) },
- Expression.Constant(custs), pred);
- //生成動(dòng)態(tài)查詢
- IQueryable
query = db.Customers.AsQueryable() - .Provider.CreateQuery
(expr);
生成的SQL語(yǔ)句為:
- SELECT [t0].[CustomerID], [t0].[CompanyName], [t0].[ContactName],
- [t0].[ContactTitle], [t0].[Address], [t0].[City], [t0].[Region],
- [t0].[PostalCode], [t0].[Country], [t0].[Phone], [t0].[Fax]
- FROM [dbo].[Customers] AS [t0] WHERE [t0].[City] = @p0
- -- @p0: Input NVarChar (Size = 6; Prec = 0; Scale = 0) [London]3.OrderBy
本例既實(shí)現(xiàn)排序功能又實(shí)現(xiàn)了過(guò)濾功能。
- IQueryable
custs = db.Customers; - //創(chuàng)建一個(gè)參數(shù)c
- ParameterExpression param =
- Expression.Parameter(typeof(Customer), "c");
- //c.City=="London"
- Expression left = Expression.Property(param,
- typeof(Customer).GetProperty("City"));
- Expression right = Expression.Constant("London");
- Expression filter = Expression.Equal(left, right);
- Expression pred = Expression.Lambda(filter, param);
- //Where(c=>c.City=="London")
- MethodCallExpression whereCallExpression = Expression.Call(
- typeof(Queryable), "Where",
- new Type[] { typeof(Customer) },
- Expression.Constant(custs), pred);
- //OrderBy(ContactName => ContactName)
- MethodCallExpression orderByCallExpression = Expression.Call(
- typeof(Queryable), "OrderBy",
- new Type[] { typeof(Customer), typeof(string) },
- whereCallExpression,
- Expression.Lambda(Expression.Property
- (param, "ContactName"), param));
- //生成動(dòng)態(tài)查詢
- IQueryable
query = db.Customers.AsQueryable() - .Provider.CreateQuery
(orderByCallExpression);
生成的SQL語(yǔ)句為:
- SELECT [t0].[CustomerID], [t0].[CompanyName], [t0].[ContactName],
- [t0].[ContactTitle], [t0].[Address], [t0].[City], [t0].[Region],
- [t0].[PostalCode], [t0].[Country], [t0].[Phone], [t0].[Fax]
- FROM [dbo].[Customers] AS [t0] WHERE [t0].[City] = @p0
- ORDER BY [t0].[ContactName]
- -- @p0: Input NVarChar (Size = 6; Prec = 0; Scale = 0) [London]4.Union
下面的例子使用表達(dá)式樹(shù)LINQ動(dòng)態(tài)查詢顧客和雇員同在的城市。
- //e.City
- IQueryable
custs = db.Customers; - ParameterExpression param1 =
- Expression.Parameter(typeof(Customer), "e");
- Expression left1 = Expression.Property(param1,
- typeof(Customer).GetProperty("City"));
- Expression pred1 = Expression.Lambda(left1, param1);
- //c.City
- IQueryable
employees = db.Employees; - ParameterExpression param2 =
- Expression.Parameter(typeof(Employee), "c");
- Expression left2 = Expression.Property(param2,
- typeof(Employee).GetProperty("City"));
- Expression pred2 = Expression.Lambda(left2, param2);
- //Select(e=>e.City)
- Expression expr1 = Expression.Call(typeof(Queryable), "Select",
- new Type[] { typeof(Customer), typeof(string) },
- Expression.Constant(custs), pred1);
- //Select(c=>c.City)
- Expression expr2 = Expression.Call(typeof(Queryable), "Select",
- new Type[] { typeof(Employee), typeof(string) },
- Expression.Constant(employees), pred2);
- //生成動(dòng)態(tài)查詢
- IQueryable
q1 = db.Customers.AsQueryable() - .Provider.CreateQuery
(expr1); - IQueryable
q2 = db.Employees.AsQueryable() - .Provider.CreateQuery
(expr2); - //并集
- var q3 = q1.Union(q2);
生成的SQL語(yǔ)句為:
- SELECT [t2].[City]
- FROM (
- SELECT [t0].[City] FROM [dbo].[Customers] AS [t0]
- UNION
- SELECT [t1].[City] FROM [dbo].[Employees] AS [t1]
- ) AS [t2]ID標(biāo)識(shí)
在前面這一點(diǎn)沒(méi)有說(shuō)到,在這里作為高級(jí)特性單獨(dú)說(shuō)下ID標(biāo)識(shí)。
這個(gè)例子說(shuō)明我們存儲(chǔ)一條新的記錄時(shí)候,ContactID作為主鍵標(biāo)識(shí),系統(tǒng)自動(dòng)分配,標(biāo)識(shí)種子為1,所以每次自動(dòng)加一。
- //ContactID是主鍵ID,插入一條數(shù)據(jù),系統(tǒng)自動(dòng)分配ID
- Contact con = new Contact()
- {
- CompanyName = "New Era",
- Phone = "(123)-456-7890"
- };
- db.Contacts.InsertOnSubmit(con);
- db.SubmitChanges();
以上就是對(duì)LINQ動(dòng)態(tài)查詢的詳細(xì)闡述。
【編輯推薦】
- 深入淺出 LINQ表達(dá)式
- LINQ基礎(chǔ)學(xué)習(xí)之LINQ to XML
- 學(xué)習(xí)心得LINQ to XML
- 淺析LINQ開(kāi)發(fā)技術(shù)之LINQ to XML
- 詳細(xì)闡述linq動(dòng)態(tài)排序
網(wǎng)頁(yè)題目:LINQ動(dòng)態(tài)查詢的全面分析
URL網(wǎng)址:http://www.5511xx.com/article/dhceehd.html


咨詢
建站咨詢
