Linq to SQL支持SQL Server
話說Linq to SQL支持SQL Server等多種數(shù)據(jù)庫的,而且應(yīng)該支持多種數(shù)據(jù)庫,到最后卻落的這個(gè)局面,是為了商業(yè)考慮還是本來技術(shù)就不成熟?不得而知。不過不管怎么說Linq to SQL的體系結(jié)構(gòu)確實(shí)是支持?jǐn)U展的。
在System.Data.Linq.Mapping這個(gè)命名空間下微軟提供了一個(gè)特性:ProviderAttribute,使用強(qiáng)類型的DataContext或使用Xml做映射的時(shí)候,該特性可以用來指定具體的數(shù)據(jù)庫提供者。如下:
- [Database(“dbo.cnblogs”)]
- [Provider(typeof(SqlProvider))]
- Public CnBlogDataContext : DataContext
- {
- }
這就表明我們的Linq to SQL支持SQL Server數(shù)據(jù)庫了,SqlProvider是實(shí)現(xiàn)了IProvider接口的(該接口存在于System.Data.Linq.Provider命名空間下)。
在DataContext初始化時(shí)執(zhí)行的Init方法里有這樣幾行代碼:
- if (model.ProviderType == null)
- {
- throw Error.ProviderTypeNull();
- }
- Type providerType = model.ProviderType;
- if (!typeof(IProvider).IsAssignableFrom(providerType))
- {
- throw Error.ProviderDoesNotImplementRequiredInterface(providerType,
- typeof(IProvider));
- }
- this.provider = (IProvider) Activator.CreateInstance(providerType);
- this.provider.Initialize(this.services, connection);
請注意的是,實(shí)際的Linq to SQL支持SQL Server,所以類圖描述的關(guān)系并不存在,但是我們從代碼中完全可以想象的到即使要擴(kuò)展也是很容易的,這就是架構(gòu)的力量,即使是昨天的設(shè)計(jì)也能應(yīng)付明天的變化。
關(guān)于Provider的初始化就介紹到這里了,在文章末尾的源代碼下載里提供了IProvider類和SqlProvider類,你可以看看初始化的過程,并想想如何構(gòu)建一個(gè)可擴(kuò)展的架構(gòu)。
【編輯推薦】