首页 > 编程 > .NET > 正文

实战 .Net 数据访问层 - 1

2024-07-10 12:59:28
字体:
来源:转载
供稿:网友
  • 网站运营seo文章大全
  • 提供全面的站长运营经验及seo技术!
  • 实战 .net 数据访问层



    l 特别说明

    本篇实战共分23段,非作者有意如此,乃受csdn发表文章之64k所限。

    虽然有几段根本没有达到64k,但估计是html source超过了这个范

    围,所以也不得不单独分段(大都是源代码),请大家谅解。

    如果有朋友需要完整文档,请发邮件给我:

    mailto:[email protected]

    l 引言

    这次的讨论是上一部分“剖析 .net 下的数据访问层技术”的一个续,但也可独立成章,为突出主题,作者就特意换了一个标题。



    关于上次的内容,大家可以参考如下链接:

    http://www.csdn.net/develop/read_article.asp?id=26689(一共六篇,id从26689到26694。也可以通过dev.csdn.net -> windows/.net进行访问)



    在以下论述中,为统一起见,作者暂时将数据访问层简称为dal(data access layer)。而在“我的方案”中,作者会介绍另一个“dal”(data access logic),为避免歧义,所有data access logic将保留全名,不再采用简称。



    需要特别说明的是,以下列出的代码全部基于.net framework 1.2实现,您也可以在.net framework 1.1上进行模拟,但某些ado.net 2.0中的更新内容可能无法使用,如:objectspaces,dbdatareader等。

    您可以通过两种方法使用.net framework 1.2:

    (1) 安装whidbey(beta)或者visual studio .net 2005(preview),这是最简单的方法;

    (2) 安装.net framework 1.2 runtime(redistributables),使用visual studio .net 2003(不支持vistual studio .net 2002)进行开发。这种方式需要注意两点:

    i. 对于windows application,在app.config中进行如下设置:

    <configuration>

    <startup>

    <supportedruntime version="v1.2.30703"/>

    </startup>

    </configuration>

    对于web application,不需要进行什么设置,在安装完.net framework 1.2 runtime后已经自动添加了对iis的支持;

    ii. 虽然可以通过visual studio .net 2003编译支持.net framework 1.2的项目,但是调试功能将不起任何作用(哪位朋友知道如何解决这个问题?)!

    另外,.net framework 1.2 runtime也可以通过安装microsoft yukon(beta)自动得到。



    ok,言归正传,以下部分就是我的方案。



    l 我的方案

    上次的讨论主要集中在现有的技术,同时,也对不同技术在实现dal时的差异做了一些分析,综合下来,无非就是这么几种:

    (1) ado.net

    ado.net是当前阶段使用.net进行dal开发的基本方式,这里的dal,也包括了对ado.net进行封装后提供更简单调用的各类实现,经典例子如:duwamish,petshop等;

    (2) o/r mapping

    由于.net framework 1.2/2.0还未正式release,包含其中的objectspaces技术暂时还未能成为在.net下进行dal开发的首选武器,但是,随着各类orm framework的逐渐成熟以及一些开发厂商的不断努力,这方面正呈现出茁壮成长的势头;

    (3) x/y mapping

    这里的x/y mapping是指除了上述o/r mapping之外的其它各类data mapping,如:xml to relation mapping,relation to xml mapping,object to xml mapping等,这部分内容不是本文重点,作者将另辟专文讨论;

    (4) distributed process

    严格来说,这个并不是真正意义上的dal技术,充其量只算锦上添花。不过,正因为考虑到dal分布式处理的可能性,作者在自己的方案中将其单独归类,并不将其作为dal的主要特性去实现。这方面的技术大家早已耳熟能详:.net remoting,webservices。



    以下,作者将给出一个自己的解决方案,通过实例,和大家一起探讨一下.net下的dal实现技术。



    u 综合现有的技术

    1. 概述

    说是解决方案,其实也就是一个“大杂烩”,作者希望通过综合现有的.net dal技术来达到generic目的,免去了为不同项目反复编写dal的无尽痛苦l,虽然绝对不是银弹,总也想为广大(我也是“受害者”之一j)dal工程师们带来一点点的改善。除此之外,ease of use也是这个解决方案必须考虑的另一难题!

    为简单起见,以下将作者的解决方案简称为:daf(data access facade) solution。



    总的来说,就作者个人观点,dal generic有两方面需要我们重点考虑:



    (1) 接口一致性:这个大部分solution都能满足,但有一点比较讨厌,就是data entity的设计!这是一个很难generic的家伙,经常让人顾此失彼l

    (2) 存储无关性:database方面可以通过provider factory实现,但xml与database的混合存储模式就比较麻烦了!随着xml在应用中的逐渐普及(yukon甚至将其集成到了database table column中),dal将不可避免地与它产生交互l(当然了,还有种变相的做法也可以解决这个问题:将所有xml问题统统隔离在dal之外j)



    下一段:http://www.csdn.net/develop/read_article.asp?id=27544
    发表评论 共有条评论
    用户名: 密码:
    验证码: 匿名发表