這篇文章主要介紹“如何使用LINQ檢索和操作數(shù)據(jù)庫(kù)”,在日常操作中,相信很多人在如何使用LINQ檢索和操作數(shù)據(jù)庫(kù)問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”如何使用LINQ檢索和操作數(shù)據(jù)庫(kù)”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
為新區(qū)等地區(qū)用戶(hù)提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及新區(qū)網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、新區(qū)網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專(zhuān)業(yè)、用心的態(tài)度為用戶(hù)提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶(hù)的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!
借助于LINQ提供的各種功能和獨(dú)有的語(yǔ)法結(jié)構(gòu),LINQ已經(jīng)被用來(lái)作為一種統(tǒng)一的數(shù)據(jù)庫(kù)訪問(wèn)技術(shù)而被廣泛使用,用以消除從數(shù)據(jù)訪問(wèn)層到數(shù)據(jù)源層出不窮的區(qū)別。通過(guò)LINQ檢索,我們已經(jīng)可以不用自己編寫(xiě)一行代碼來(lái)從數(shù)據(jù)庫(kù)獲取到數(shù)據(jù),LINQ和SQL之間提供了一個(gè)直接映射關(guān)系,它可以通過(guò)我們事先指定的數(shù)據(jù)庫(kù)連接自動(dòng)生成數(shù)據(jù)庫(kù)實(shí)體類(lèi),而我們只需要通過(guò)LINQ語(yǔ)句操作這些實(shí)體對(duì)象就可以非常輕松地從數(shù)據(jù)庫(kù)中獲取到數(shù)據(jù)。當(dāng)然,LINQ所生成的實(shí)體對(duì)象的功能遠(yuǎn)遠(yuǎn)不止這些,它甚至支持?jǐn)?shù)據(jù)的更新和存儲(chǔ)過(guò)程的調(diào)用,所有這些都可以通過(guò)簡(jiǎn)單的幾行LINQ語(yǔ)句來(lái)完成,讓我們真正擺脫了編寫(xiě)數(shù)據(jù)訪問(wèn)層、數(shù)據(jù)庫(kù)實(shí)體類(lèi)的工作。
下面就讓我們來(lái)看看LINQ的神奇功能吧!
使用LINQ生成數(shù)據(jù)庫(kù)實(shí)體類(lèi)
Visual Studio 2008集成開(kāi)發(fā)環(huán)境為我們提供了很多有用的功能來(lái)實(shí)現(xiàn)LINQ to SQL。為了讓讀者可以自行嘗試本文所舉的示例,讀者可能需要在本地安裝一個(gè)SQL Server數(shù)據(jù)庫(kù)實(shí)例,Northwind是微軟官方提供的一個(gè)不錯(cuò)的例子,如果你本地沒(méi)有安裝這個(gè)實(shí)例,可以去下面這個(gè)地址下載:
http://www.microsoft.com/downloads/details.aspx?FamilyID=06616212-0356-46A0-8DA2-EEBC53A68034&displaylang=en
我們?cè)赩isual Studio 2008中新建一個(gè)控制臺(tái)應(yīng)用程序,取名為L(zhǎng)INQExample,然后打開(kāi)Server Explorer窗口并連接到Northwind數(shù)據(jù)庫(kù)。如果找不到Server Explorer窗口,可以通過(guò)View-Server Explorer菜單打開(kāi)。
在Server Explorer窗口中,右鍵單擊Data Connection節(jié)點(diǎn),選擇Add Connection,在彈出的窗口中選擇Northwind數(shù)據(jù)庫(kù)。
在工程中添加Northwind.dbml文件,該文件是LINQ to SQL Classes類(lèi)型的文件。
然后將Server Explorer窗口中Northwind數(shù)據(jù)庫(kù)中的所有Table和Stored Procedures拖放到Northwind.dbml視圖窗口中。此時(shí),在Northwind.dbml文件中,Visual Sdutio已經(jīng)自動(dòng)為我們創(chuàng)建了數(shù)據(jù)庫(kù)實(shí)體類(lèi)和映射到數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程的靜態(tài)方法,在后面的示例中我們可以通過(guò)LINQ語(yǔ)句直接使用它們。
打開(kāi)Class View窗口,在其中也可以看到自動(dòng)生成的實(shí)體類(lèi)和靜態(tài)方法。
是不是非常方便???那接下來(lái)就來(lái)看看如何通過(guò)LINQ檢索和修改數(shù)據(jù)。
使用LINQ檢索數(shù)據(jù)
LINQ檢索提供的語(yǔ)法結(jié)構(gòu)與SQL比較接近,這讓我們使用起來(lái)更加容易上手。Northwind.dbml自動(dòng)包裝了一個(gè)上下文對(duì)象NorthwindDataContext類(lèi),其中包括了我們?cè)贜orthwind數(shù)據(jù)庫(kù)中要使用的所有實(shí)體類(lèi)和存儲(chǔ)過(guò)程映射方法,同時(shí)還提供了操作表數(shù)據(jù)的方法,使用時(shí)我們不需要去關(guān)心它是如何連接數(shù)據(jù)庫(kù)并進(jìn)行底層數(shù)據(jù)操作的。事實(shí)上,Northwind.dbml文件中已經(jīng)包含了這些基礎(chǔ)設(shè)施!使用記事本打開(kāi)Northwind.dbml,可以發(fā)現(xiàn)這是一個(gè)純粹的XML結(jié)構(gòu)化文件,里面包含了數(shù)據(jù)庫(kù)連接字符串和一些數(shù)據(jù)庫(kù)實(shí)體類(lèi)的映射關(guān)系,同時(shí),Northwind.designer.cs文件中也做了很多基礎(chǔ)性的工作,感興趣的讀者可以自行研究其中的代碼,或許對(duì)解決實(shí)際問(wèn)題有所幫助。本文在這里不對(duì)這個(gè)文件的具體結(jié)構(gòu)作詳細(xì)的解釋。
下面的這個(gè)例子展示了通過(guò)LINQ檢索Northwind數(shù)據(jù)庫(kù)中Customers表City等于London的數(shù)據(jù),并在Command窗口中打印出來(lái)。
using (NorthwindDataContext context =new NorthwindDataContext()) { var results = from curstomers in context.Customers
where curstomers.City =="London"
orderby curstomers.CompanyName
select curstomers;
foreach (var curstomers in results)
{
Console.WriteLine("Company is {0} and Contact is {1}",
curstomers.CompanyName, curstomers.ContactName);
}
// Pause to see the output
Console.ReadLine();
}
這個(gè)是執(zhí)行結(jié)果:
使用LINQ更新數(shù)據(jù)
LINQ不僅可以從數(shù)據(jù)庫(kù)中檢索數(shù)據(jù),借助于NorthwindDataContext上下文對(duì)象提供的方法,我們也可以通過(guò)LINQ非常方便地將數(shù)據(jù)更新到數(shù)據(jù)庫(kù)中。下面的例子展示了將數(shù)據(jù)Insert和Update到數(shù)據(jù)庫(kù)并從數(shù)據(jù)庫(kù)中刪除數(shù)據(jù),其中使用了LINQ中的lambda表達(dá)式用于從數(shù)據(jù)源查詢(xún)數(shù)據(jù)(lambda表達(dá)式是LINQ查詢(xún)語(yǔ)句的一種簡(jiǎn)寫(xiě)形式)。
using(NorthwindDataContextcontext=newNorthwindDataContext()) { //AddanewrecordandverifyitexiststhroughCount varcustomer=newCustomer()
{
CompanyName="DramaCafe",
CustomerID="DRACA",
ContactName="TomSmith",
City="BeverlyHills",
Address="123MelrosePlace",
PostalCode="90210"
};
context.Customers.InsertOnSubmit(customer);
context.SubmitChanges();
Console.WriteLine("NumberofDRACArecords:{0}",context.Customers.Where(c=>c.CustomerID=="DRACA").Count());
//ModifytherecordandverifyitischangedthroughCount
customer.ContactName="JoeSmith";
context.SubmitChanges();
Console.WriteLine("NumberofJoeSmithrecords:{0}",context.Customers.Where(c=>c.ContactName=="JoeSmith").Count());
//DeletearecordandverifyitisremovedthroughCount
context.Customers.DeleteOnSubmit(customer);
context.SubmitChanges();
Console.WriteLine("NumberofDRACArecords:{0}",context.Customers.Where(c=>c.CustomerID=="DRACA").Count());
//Pausetoseetheoutput
Console.ReadLine();
}
這個(gè)是執(zhí)行結(jié)果:
使用LINQ執(zhí)行存儲(chǔ)過(guò)程
在前面我們已經(jīng)看到,Northwind.dbml在生成數(shù)據(jù)庫(kù)實(shí)體類(lèi)的同時(shí),也生成了映射數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程的靜態(tài)方法,通過(guò)NorthwindDataContext上下文對(duì)象我們可以直接在LINQ中調(diào)用這些存儲(chǔ)過(guò)程。下面的例子展示了在LINQ中調(diào)用Ten_Expensive_Products存儲(chǔ)過(guò)程,用于檢索Products表中單價(jià)最貴的10中商品的名稱(chēng)。
using(NorthwindDataContextcontext=newNorthwindDataContext()) { //Usethetenmostexpensiveproductsstoredprocedure varresults=fromproductsincontext.Ten_Most_Expensive_Products()
selectproducts;
foreach(varproductinresults)
{
Console.WriteLine("Productpriceis{0}",product.UnitPrice);
}
//Pausetoseetheoutput
Console.ReadLine();
}
這個(gè)是執(zhí)行結(jié)果:
LINQ檢索結(jié)語(yǔ)
使用LINQ檢索數(shù)據(jù)庫(kù)確實(shí)可以為我們開(kāi)發(fā)數(shù)據(jù)庫(kù)應(yīng)用程序帶來(lái)許多的便利性,例如省去編寫(xiě)數(shù)據(jù)庫(kù)實(shí)體類(lèi)和數(shù)據(jù)庫(kù)訪問(wèn)層的代碼,但這同時(shí)也會(huì)帶來(lái)一些問(wèn)題!例如在大型應(yīng)用項(xiàng)目中這將破壞整體項(xiàng)目的結(jié)構(gòu),而且難以做到應(yīng)用層與數(shù)據(jù)訪問(wèn)層的松耦合結(jié)構(gòu),另外就是涉及到復(fù)雜數(shù)據(jù)庫(kù)事務(wù)時(shí)LINQ往往難以應(yīng)付,一個(gè)好的解決辦法就是將事務(wù)移至數(shù)據(jù)庫(kù),在存儲(chǔ)過(guò)程中解決事務(wù)問(wèn)題,然后在數(shù)據(jù)訪問(wèn)層統(tǒng)一調(diào)用存儲(chǔ)過(guò)程,不過(guò)有些非常特殊的應(yīng)用層需求還是會(huì)存在問(wèn)題。從這個(gè)意義上來(lái)看,LINQ仍然不可能全部替代傳統(tǒng)意義上的數(shù)據(jù)庫(kù)訪問(wèn)層,不過(guò)在一些小型應(yīng)用或快速原型開(kāi)發(fā)中,使用LINQ確實(shí)可以給我們省去很多麻煩。
還有一點(diǎn)需要說(shuō)明的是,鑒于Visual Studio可以允許我們?cè)赟erver Explorer中連接除SQL之外的其它數(shù)據(jù)庫(kù),這也就意味著我們可以通過(guò)LINQ訪問(wèn)其它類(lèi)型的數(shù)據(jù)庫(kù)。我們可以在工程中創(chuàng)建多個(gè)不同的dbml文件,用以連接不同類(lèi)型的數(shù)據(jù)庫(kù),然后在上層使用工廠進(jìn)行調(diào)用切換,就可以達(dá)到支持多數(shù)據(jù)庫(kù)應(yīng)用的目的。有關(guān)這一點(diǎn),讀者可以自己去嘗試。
到此,關(guān)于“如何使用LINQ檢索和操作數(shù)據(jù)庫(kù)”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
名稱(chēng)欄目:如何使用LINQ檢索和操作數(shù)據(jù)庫(kù)
URL網(wǎng)址:http://jinyejixie.com/article28/jjhecp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、品牌網(wǎng)站建設(shè)、企業(yè)建站、商城網(wǎng)站、網(wǎng)站維護(hù)、響應(yīng)式網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)