如何实现LINQ自定义业务

编者按:LINQ的基本概念大家应该都已经有所了解了,不过理论和实际总会有那么点差距。LINQ自定义业务就属于LINQ的一个很典型的应用,下面,我们就来一起看一看究竟怎么来实现LINQ自定义业务。

LINQ TO SQL很好很强大,它几乎包含了我们能够想到的所有与数据库有关的操作,甚至也包含了一些我们可能都没有想到的。

但不管怎样,也许我们需要在LINQ TO SQL的操作中添加一个LINQ自定义业务逻辑,例如在插入某个实体的时候编写日志等等。如何实现这样的功能呢?

其实这一点,LINQ TO SQL在设计的时候也考虑到了。我们可以打开那个dtml文件的designer.cs文件,我们发现有些隐藏的代码

首先,我们看到NorthwindDataContext这个类型是一个局部类型(Partial Class),而且上述定义的一些方法也是局部方法(Partial Method)

局部方法是C# 3.0的新增特性。它使用在如下场景:

某个方法可有可无。通过partial 关键字声明的目的是,可以让其他地方代码可以调用它。但如果该方法最终没有被实现,那么包括方法声明以及调用代码都会被删除掉。

这个特性与虚方法,抽象方法都不同。

假设我们需要在InsertCustomer的时候添加一些业务逻辑,那么该怎么做呢?

 
 
 
 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;   
  5.  
  6. namespace Model  
  7. {  
  8.     public partial class NorthwindDataContext  
  9.     {  
  10.         partial void InsertCustomer(Customer instance)  
  11.         {  
  12.            //这里可以实现自己的保存逻辑,根据传入的一个Customer的实例   
  13.  
  14.             this.ExecuteCommand("Insert Into.....");  
  15.             //还可以写日志,等等  
  16.         }  
  17.     }  
  18. }  

【注意】一旦我们这样做了,那么插入Customer的逻辑就全部由我们来负责了。你需要确保这里面的代码是完整的

 
 
 
 
  1. protected void addcustomer_Click(object sender, EventArgs e)  
  2. {  
  3.     Model.NorthwindDataContext db = new Model.NorthwindDataContext(connectionString);  
  4.     Model.Customer c = new Model.Customer()  
  5.     {  
  6.         CustomerID = "AAAAAS",  
  7.         CompanyName = "Xizhang" 
  8.     };   
  9.  
  10.     db.Customers.InsertOnSubmit(c);  
  11.     db.SubmitChanges();   
  12.  

在db.SubmitChanges方法被调用后,会自动调用我们写的那个InsertCustomer方法,也就实现了LINQ自定义业务。

本文出自博客园,作者陈希章

【编辑推荐】

  1. 实例二:绑定到LINQ查询的结果
  2. LINQ——语言级集成查询入门指南
  3. LINQ查询表达式深入剖析
  4. LINQ查询的目的与实现手段
  5. LINQ的演变及其对C#设计的影响

本文题目:如何实现LINQ自定义业务
转载注明:http://www.csdahua.cn/qtweb/news26/468376.html

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

广告

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