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。经常看到LinQ那到底是什么呢?他是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

2017-02-23 14:27:05

信息化信息孤岛教育信息化

2010-07-08 15:56:52

UML类图依赖关系

2010-09-02 10:12:34

CSS导航

2012-12-13 09:45:32

BYOD移动通信

2009-09-17 15:22:38

LINQ to SQL

2010-10-21 14:21:15

SQL Server视

2015-07-17 09:50:16

Carthage优劣比较

2011-03-21 09:01:49

CSS框架

2010-04-07 15:06:26

Windows HPC高性能计算微软

2010-11-12 11:36:29

SQL Server视

2010-07-22 09:14:51

SQL Server全

2013-01-06 10:44:43

微软Windows 8云计算

2016-03-30 11:51:55

2013-05-20 08:56:13

2009-09-16 16:59:05

LINQ to XML

2009-09-10 14:37:57

LINQ匿名类型
点赞
收藏

51CTO技术栈公众号