成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

LinQ to SQL四大護法剖析

開發 后端
這里介紹LinQ to SQL四大護法,LinQ to SQL是一種ORM,它允許你通過編寫.NET程序來控制或操作關系型數據庫以達到查詢的效果。你可以使用LinQ來檢索數據庫中的數據,也可以通過其進行數據的更新和添加。

在向大家詳細介紹LinQ to SQL之前,首先讓大家了解下LinQ to SQL四大護法,以后全面介紹LinQ to SQL。

我們來看看LinQ to SQL,就是對數據庫的查詢,以前叫做DLinQ。經??吹絃inQ那到底是什么呢?他是Language Integrated Query的縮寫,以一種類似SQL語句的形式來對對象進行操作的編程方法。

在使用到LinQ時也會用到以前提到過的一些特性,如:匿名類型,自動化屬性等等。

LinQ to SQL是一種ORM,它允許你通過編寫.NET程序來控制或操作關系型數據庫以達到查詢的效果。你可以使用LinQ來檢索數據庫中的數據,也可以通過其進行數據的更新和添加。同時LinQ to SQL也支持事務,試圖以及存儲過程等等,通過VS2008(現在使用的是beta版本,下同)的LinQ to SQL設計器我們可以很容易定義一些實體類,我們可以通過添加一個新項來加入.dbml文件,并從數據庫服務器窗口拖出數據表。

我們定義兩個實體類,Artile和Category,我們也可以把存儲過程拖到方法的窗口中,由于我們的存儲過程和數據表的命名可能帶有前綴或其他標識,我們可以查看屬性窗口將他們的name屬性改掉我們容易識別的名稱。我們打開Designer.cs那個文件看一下,是不是生成了幾個類,其中一個最重要的是以DataContext為后綴那個類(他以當前dbml文件名加DataContext為名稱的類),他是這個LinQ的上下文,我們可以通過他來執行我們的操作。而上面兩個是外鍵關系,他還生成了一個關系類,而且在Category類中好有一個Article的集合,在Article中也有一個關聯屬性,在賦值時還會對鍵值類型進行判斷。

下面我們來看看實際應用的一些例子(LinQ to SQL四大護法<SELECT/INSERT/UPDATE/DELETE>):

1.從數據庫中檢索數據<SELECT>

  1. //三個重載(),(string connectionString),(IDbConnection connection)  
  2. ItLivesNetDataContext cntx = new ItLivesNetDataContext();  
  3. //這個也可以在初始化ItLivesNetDataContext實例時直接進行初始化。  
  4. cntx.Connection = new SqlConnection
    (ConfigurationManager.ConnectionStrings[0].ConnectionString);  
  5. var articles = from a in cntx.Articles  
  6. where a.CategoryID == 1  
  7. orderby a.PostDate descending  
  8. select a;  

上面的代碼將返回數據庫Articles表中類型ID為1的所有數據,并將其按發布時間進行降序排列。其中articles其實是IEnumerable<T>的實例,這個例子的T就是Article實體類。

2.將新數據插入到數據庫中<INSERT>

  1. //插入新類型C++  
  2. Category category = new Category   
  3. CategoryName="CPLUSPLUS",IsActived=trueParentID = 1 };  
  4. //插入新文章,類型為C++  
  5. var article = new Article { Subject = "C++入門"Author="網魂小兵" };   
  6. category.Articles.Add(article);  
  7. cntx.Categories.Add(category);  
  8. cntx.SubmitChanges();  

3.更新新數據<UPDATE>

  1. Category category = cntx.Categories.Single(p =>
    p.CategoryName.ToUpper() == "CSHARP");  
  2. category.IsActived = true;  
  3. category.Description = "UPDATE CSHARP!";  
  4. cntx.SubmitChanges();  

4.刪除數據庫中的數據<DELETE>

  1. var delArtiles = from s in cntx.Articles  
  2. where s.CategoryName == "CPLUSPLUS"  
  3. select s;  
  4. cntx.Articles.RemoveAll(delArtiles);  
  5. cntx.SubmitChanges();  

以上是LinQ to SQL四大護法的例子,例子很簡單一看就能夠懂就不多解釋了。在數據庫中我們還經常要用到檢索數據庫的方法那就是分頁檢索數據庫,然而在比較大的數據時我們往往會用到存儲過程來完成這一職業。

【編輯推薦】

  1. Linq匿名委托類型
  2. Linq異常處理詳細介紹
  3. Linq Setting字段描述
  4. Linq數據和對象淺談
  5. Linq內部執行原理剖析
責任編輯:佚名 來源: 51CTO.com
相關推薦

2009-09-09 14:40:43

Linq to sql

2009-09-07 16:25:14

Linq To SQL

2009-09-08 16:20:12

LINQ to SQL

2009-09-16 09:56:42

LINQ to SQL

2010-09-02 10:12:34

CSS導航

2012-12-13 09:45:32

BYOD移動通信

2010-07-08 15:56:52

UML類圖依賴關系

2017-02-23 14:27:05

信息化信息孤島教育信息化

2010-10-21 14:21:15

SQL Server視

2015-07-17 09:50:16

Carthage優劣比較

2009-09-17 15:22:38

LINQ to SQL

2011-03-21 09:01:49

CSS框架

2010-04-07 15:06:26

Windows HPC高性能計算微軟

2013-05-20 08:56:13

2016-03-30 11:51:55

2013-01-06 10:44:43

微軟Windows 8云計算

2010-07-22 09:14:51

SQL Server全

2010-11-12 11:36:29

SQL Server視

2009-09-10 14:37:57

LINQ匿名類型

2009-09-16 16:59:05

LINQ to XML
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 午夜视频免费网站 | 国产精品久久久久久久久久久久 | 成人妇女免费播放久久久 | 中文字幕一区二区三区不卡在线 | 欧美一区二区在线观看 | 丝袜美腿一区二区三区动态图 | www久久| 久久久av | 成人在线视频一区二区三区 | 欧美自拍第一页 | 国产大片黄色 | 精品久久久久一区二区国产 | a级大片 | 香蕉大人久久国产成人av | 欧美一级免费 | 黄色av一区 | 精品久久久久一区二区国产 | 成年人在线视频 | www.中文字幕av | 欧美成人免费在线视频 | 欧美国产日韩在线 | 久久久不卡网国产精品一区 | 视频一区二区中文字幕 | 中文字幕高清 | 日韩欧美中文字幕在线视频 | 精品国产黄色片 | 国产在线精品一区二区三区 | 黑人精品xxx一区一二区 | 欧美日韩视频 | 日韩国产在线 | 国产一级片av | 国产一级毛片精品完整视频版 | 自拍偷拍视频网 | 一级毛片高清 | 亚洲第一网站 | 欧美精品一区二区三区在线四季 | 午夜影院在线观看免费 | 国产一区高清 | 欧洲精品码一区二区三区免费看 | 国产高清免费 | 少妇精品亚洲一区二区成人 |