LinQtoSQL四大护法剖析

在向大家详细介绍LinQ to SQL之前,首先让大家了解下LinQ to SQL四大护法,以后全面介绍LinQ to SQL。

成都创新互联公司是专业的东海网站建设公司,东海接单;提供网站制作、成都网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行东海网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!

我们来看看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=true, ParentID = 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四大护法的例子,例子很简单一看就能够懂就不多解释了。在数据库中我们还经常要用到检索数据库的方法那就是分页检索数据库,然而在比较大的数据时我们往往会用到存储过程来完成这一职业。

分享题目:LinQtoSQL四大护法剖析
网站路径:http://www.shufengxianlan.com/qtweb/news8/27158.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联