如何實現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的時候添加一些業務邏輯,那么該怎么做呢?
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- namespace Model
- {
- public partial class NorthwindDataContext
- {
- partial void InsertCustomer(Customer instance)
- {
- //這里可以實現自己的保存邏輯,根據傳入的一個Customer的實例
- this.ExecuteCommand("Insert Into.....");
- //還可以寫日志,等等
- }
- }
- }
【注意】一旦我們這樣做了,那么插入Customer的邏輯就全部由我們來負責了。你需要確保這里面的代碼是完整的
- protected void addcustomer_Click(object sender, EventArgs e)
- {
- Model.NorthwindDataContext db = new Model.NorthwindDataContext(connectionString);
- Model.Customer c = new Model.Customer()
- {
- CustomerID = "AAAAAS",
- CompanyName = "Xizhang"
- };
- db.Customers.InsertOnSubmit(c);
- db.SubmitChanges();
- }
在db.SubmitChanges方法被調用后,會自動調用我們寫的那個InsertCustomer方法,也就實現了LINQ自定義業務。
本文出自博客園,作者陳希章
【編輯推薦】