DAL是指Data Access Layer。DALFactory是用于创建数据訪问对象的工厂。本质上是採用了抽象工厂的设计模式。目的是支持多种数据訪问层,比方sql server和oracle两种实现。同一时候又利用了.net的反射机制,通过配置文件就可以确定採用哪种数据訪问实现;IDAL是数据訪问层接口,这样做的优点是使业务逻辑层调用数据訪问层的接口就可以实现数据库的增删改等操作,业务逻辑层与数据訪问层是一种抽象依赖的关系,而非详细依赖。我认为明确这些,首先须要有编程的经验,要明确接口、抽象类等的作用,再研究设计模式和软件架构。能够上博客园、csdn什么的多看看这方面的资料呗。

  1、WEB=表示层





  2、BLL=业务逻辑层





  3、IDAL=数据訪问层接口定义





  4、Model=业务实体





  5、DALFactory=数据层的抽象工厂(创建反射)





  6、SQLServerDAL=SQLServer数据訪问层 / OracleDAL=Oracle数据訪问层





  DBUtility 数据库訪问组件基础类





  二、项目引用关系





  1、Web 引用 BLL。





  2、BLL 引用 IDAL,Model,使用DALFactory创建实例。

  3、IDAL 引用 Model。





  4、Model 无引用。





  5、DALFactory 引用IDAL。通过读取web.config里设置的程序集,载入类的实例,返回给BLL使用。





  6、SQLServerDAL 引用 Model和IDAL,被DALFactory载入的程序集,实现接口里的方法。





  三、实现步骤





  1、创建Model,实现业务实体。





  2、创建IDAL。实现接口。





  3、创建SQLServerDAL。实现接口里的方法。

  4、添加web.config里的配置信息,为SQLServerDAL的程序集。





  5、创建DALFactory。返回程序集的指定类的实例。





  6、创建BLL。调用DALFactory。得到程序集指定类的实例,完毕数据操作方法。





  7、创建WEB,调用BLL里的数据操作方法。





  注意:





  1、web.config里的程序集名称必须与SQLServerDAL里的输出程序集名称一致。





  2、DALFactory里仅仅须要一个DataAccess类,能够完毕创建全部的程序集实例。





  3、项目创建后,注意改动各项目的默认命名空间和程序集名称。

  4、注意改动解决方式里的项目依赖。

  5、注意在解决方式里添加各项目引用。

DALFactory有什么作用的更多相关文章

  1. if __name__== "__main__" 的意思(作用)python代码复用

    if __name__== "__main__" 的意思(作用)python代码复用 转自:大步's Blog  http://www.dabu.info/if-__-name__ ...

  2. (转载)linux下各个文件夹的作用

    linux下的文件结构,看看每个文件夹都是干吗用的/bin 二进制可执行命令 /dev 设备特殊文件 /etc 系统管理和配置文件 /etc/rc.d 启动的配置文件和脚本 /home 用户主目录的基 ...

  3. github中的watch、star、fork的作用

    [转自:http://www.jianshu.com/p/6c366b53ea41] 在每个 github 项目的右上角,都有三个按钮,分别是 watch.star.fork,但是有些刚开始使用 gi ...

  4. web.xml中welcome-file-list的作用

    今天尝试使用struts2+ urlrewrite+sitemesh部署项目,结果发现welcome-file-list中定义的欢迎页不起作用: <welcome-file-list> & ...

  5. web.xml中load-on-startup的作用

    如下一段配置,熟悉DWR的再熟悉不过了:<servlet>   <servlet-name>dwr-invoker</servlet-name>   <ser ...

  6. SQLSERVER中NULL位图的作用

    SQLSERVER中NULL位图的作用 首先感谢宋沄剑提供的文章和sqlskill网站:www.sqlskills.com,看下面文章之前请先看一下下面两篇文章 SQL Server误区30日谈-Da ...

  7. 电容与EMC-电容不同功能时对整板EMC的作用

    一般我们的pcb板的器件有很多种类,但是值得特别关注的,很多人都会说是BGA.接口.IC.晶振之类,因为这些都是layout功能模块以及设计难点.然而数量上占绝对优势的器件却是阻容器件,之前围殴阻抗时 ...

  8. FTP的搭建与虚拟目录作用<之简单讲解>

    操作系统:win7 VS2010编写WebService与在IIS的发布<之简单讲解>中我已经说了IIS安装与使用,不明白的可以跳过去看. 1.添加FTP站点 2. 3. 4. 5. zq ...

  9. 火狐浏览器中event不起作用解决办法--记录(一)

    今天遇到了这个问题.IE,谷歌下都没问题,但在FF下却不起作用,很郁闷查了半天,看别人博文写了老长,结果试了要么起作用,但太麻烦,要么不起作用,说了那么多跟没说一样. 其实只要这一句代码就行:e=ar ...

随机推荐

  1. iOS archiveRootObject 归档失败问题

    归档失败问题出在路径上,NSHomeDirectory() NSString *stringPath = [NSSearchPathForDirectoriesInDomains(NSDocument ...

  2. AP_标准采购单付基本操作(流程)

    2014-06-04 Created By BaoXinjian

  3. uploadify上传图片

    1.实现源代码 <%@ page language="java" import="java.util.*" pageEncoding="UTF- ...

  4. Shell中重定向&lt;&lt;EOF注意事项

    作者:iamlaosong 我们常常在shell脚本程序中用<<EOF重定向输入.将我们输入的命令字符串作为一个运行程序的输入,这样,我们就不须要在那个程序环境中手工输入命令,以便自己主动 ...

  5. docker lnmp php

    使用 Docker 构建 LNMP 环境 https://segmentfault.com/a/1190000008833012 Docker 快速上手指南 https://segmentfault. ...

  6. html中一些常用标签及属性

    html中标签分为块级标签和行级标签 块级标签常用的有 <div> <p> <h1><hr><pre><table><ul ...

  7. mysql-5.7 innodb_buffer_pool刷新机制详解

    一.innodb的脏页刷新机制说明: 1.当innodb中的脏页比例超过innodb_max_dirty_pages_pct_lwm的值时,这个时候innodb就会开始刷新脏页到磁盘. 2.当inno ...

  8. js获取当前页面url网址等信息

    使用js获取当前页面的url网址信息. 1.设置或获取整个 URL 为字符串: window.location.href 2.设置或获取与 URL 关联的端口号码: window.location.p ...

  9. cocos2d-x开发记录:一,搭建环境

    首先我下载的cocos2D版本为2.1.2版本,我们安装好VS后,新建一个解决方案,这里很重要,假设我的cocos解压后的路径为E:\cocos2d-2.1rc0-x-2.1.2-hotfix\coc ...

  10. 【Android】6.0 第6章 对话框--本章示例主界面

    分类:C#.Android.VS2015: 创建日期:2016-02-08 在Android应用中,常用的对话框有:Toast.AlertDialog.ProgressDialog.时间选择对话框.日 ...