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. 【LeetCode】131. Palindrome Partitioning

    Palindrome Partitioning Given a string s, partition s such that every substring of the partition is ...

  2. 【LeetCode】53. Maximum Subarray (2 solutions)

    Maximum Subarray Find the contiguous subarray within an array (containing at least one number) which ...

  3. SVN 使用学习记录

    一.基本SVN操作 安装了SVN之后,在本机上点击右键,就能够看到如下信息: 1.建立SVN Repository 下面来建立一个SVN Repository.这个文件夹是同步用的,你可以放在本机的任 ...

  4. 【js】replace()

    replace方法的语法是: stringObj.replace(rgExp, replaceText) 其中stringObj是字符串(string),reExp可以是正则表达式对象(RegExp) ...

  5. codeforces#254DIV2解题报告

    今天简直大爆发啊... 吃了顿烧烤竟然这么管事. . . .. 本弱渣竟然做出来了3道,并且B题是我第一次在CF中用到算法..(曾经最多也就是贪心. . . ). 题目地址:codeforces#22 ...

  6. react 事件绑定的2种常用方式

    方式一:传统 import React, { Component } from 'react'; class App extends Component { handleSubmit (e, args ...

  7. php 利用转转法去除重复数组

    w3scool学习地址 http://www.w3school.com.cn/tiy/s.asp?f=demo_php_func_array_flip 利用array键名不能重复的原理,使用两次 ar ...

  8. 将mysql非分区表转换为分区表(转)

    查看表的分布状况mysql> select count(*) from  justin;+----------+| count(*) |+----------+|  5845246 |+---- ...

  9. 在 Windows 8 中启用可匿名访问的共享

    就是不用输入用户名和密码,直接通过网上邻居可以访问的共享. 1.打开本地组策略编辑器(快捷键Win+R,打开运行,输入gpedit.msc,确定): 2.打开:"本地计算机策略->计算 ...

  10. Windows Azure Mobiles Services实现client的登录注冊

    下文仅仅是简单实现,client以Android端的实现为例: 用户表Account: package com.microsoft.ecodrive.model; public class Accou ...