Microsoft .NET Pet Shop 4.0 学习之旅(二) - 项目的引用关系1

Microsoft .NET Pet Shop 4.0 学习之旅(二)

项目的引用关系1

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

初看到Pet Shop 4.0的源代码觉得结构很复杂,今天我只讨论业务逻辑层(BLL)以下层。我抽象出了基本的6层,他们是:DBUtilityModelSQLServerDALIDALDALFactoryBLL

<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" />

项目结构.jpg 

1,  物理访问层【DBUtility】:负责数据库的存、取操作,包含数据库连接字符串信息和公共静态方法(完成数据库增,删,改,查)。他不引用别的任何层,属于最底层。

2,  业务实体层【Model】:负责数据库表的抽象,将数据库的表抽象成实体对象类(拥有私有成员和属性公共方法)。一个Model的实例(instance)对应数据库表的一条记录。他也不引用其他任何层,属于较底层。

3,  数据访问层【SQLServerDAL】:负责拼写数据访问的SQL语句和存储过程,然后进行处理,并将数据库返回的结果集装在自己(SQLServerDAL)的肚子里面,等待其他层调用。SQLServerDAL拿到Model的属性拼写出SQL字符串,然后放进DBUtility(机器)中执行,得到数据集(DataSet)。所以SQLServerDAL引用Model所以SQLServerDAL引用DBUtility。因为IDALSQLServerDAL的接口层,用来定义数据访问层的名词空间和返回类型的。SQLServerDAL封装了接口的处理方法。他将继承于接口层。所以SQLServerDAL引用IDAL

4,  数据访问接口层【IDAL】:是SQLServerDAL的方法抽象,SQLServerDAL处理的数据对象是Model,于是IDAL处理的参数(名词空间)同样是Model所以IDAL引用了Model

5,  基于上面的4个项目,4条关系,我们很清晰的得到下面的项目关系图形:
结构1.jpg

总结:IDAL引用ModelSQLServerDAL引用ModelSQLServerDAL引用DBUtilitySQLServerDAL引用IDAL

 

6,  由于时间的关系,下一次介绍另外2个项目和4条关系:

 

结构2.jpg 


注意!在博客园社区以外转载,必须注明:
作者:Clark Chan
和原文出处:http://clarkchan.cnblogs.com/
否则谢绝转载!

//

转载于:https://www.cnblogs.com/ClarkChan/archive/2006/09/22/512104.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/569058.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java api在线

地址&#xff1a;http://dlc-cdn.sun.com/jdk/jdk-api-localizations/jdk-api-zh-cn/builds/latest/html/zh_CN/api/点击打开链接 转载于:https://www.cnblogs.com/dengshiwei/p/4258607.html

SQL Server检索存储过程的结果集

目的&#xff1a;检索过滤执行存储过程的结果集 如下介绍两个常用的方法&#xff0c;但是都需要申明表结构&#xff1b;不知道是否有更简便的方法&#xff0c;如有更好的方法&#xff0c;请不吝赐教。 以系统存储过程sp_who2为例&#xff1a; 方法1&#xff1a;使用临时表 1 --…

zsh of termux

termux-ohmyzsh script :sh -c "$(curl -fsSL https://github.com/Cabbagec/termux-ohmyzsh/raw/master/install.sh)" one step in place recommend style ; gentoo 转载于:https://www.cnblogs.com/jiujue/p/11272706.html

zsh of kali

首先安装zsh&#xff1a; # apt-get update # apt-get install zsh -y然后直接使用仓库脚本&#xff1a; # sh -c "$(wget https://raw.githubusercontent.com/robbyrussell/oh-my-zsh/master/tools/install.sh -O -)" 作者&#xff1a;NextStack链接&#xff1a;htt…

python的zip()函数

zip() 函数用于将可迭代对象作为参数&#xff0c;将对象中对应的元素打包成一个个元组&#xff0c;然后返回由这些元组组成的对象。 如果各个可迭代对象的元素个数不一致&#xff0c;则返回的对象长度与最短的可迭代对象相同。 利用 * 号操作符&#xff0c;与zip相反&#xff0…

django小知识

def __str__:return self.name 在显示的时候&#xff0c;将原来显示的额object对象&#xff0c;显示成这个类的名字 转载于:https://www.cnblogs.com/one-tom/p/11275894.html

RT-Thread中如何预编译一个.c文件

本文介绍在RT-Thread系统&#xff0c;使用scons&#xff0c;如何预编译一个.c文件 首先新建一个测试文件test.c #include "rtthread.h"void test(void) { rt_kprintf("Hello RT-Thread\n"); } 使用下面的命令导出编译过程到1.txt文件 scons -j7 --verbose …

vs.net各版本解决方案相互转换工具

感谢Arthur Liberman, 感谢zu14.cn三角猫 工具下载转载于:https://www.cnblogs.com/JoinZhang/archive/2010/07/09/1774617.html

杂谈杂想!

a) 在Live Write 实施插入地图 b) 金山词霸为什么总是把“音乐(YUE)”念成“音乐&#xff08;LE&#xff09;”&#xff1f;这个bug好多年&#xff01; c) 养的基瘦了&#xff0c;人却变胖了&#xff01; 转载于:https://www.cnblogs.com/jeffersyuan/archive/2007/11/10/95528…

链接Mysql的api mysqli和pdo

HP 5 及以上版本建议使用以下方式连接 MySQL : MySQLi extension ("i" 意为 improved)PDO (PHP Data Objects)PDO 应用在 12 种不同数据库中&#xff0c; MySQLi 只针对 MySQL 数据库。 如果你的项目需要在多种数据库中切换&#xff0c;建议使用 PDO 两者都是面向对…

Spring 实战-第一章-基本概念

依赖注入&#xff08;Dependency Injection&#xff0c;DI&#xff09;通过第三方配置初始化对象&#xff0c;而不是把具体的实现写在对象中&#xff0c;这样程序入口与具体实现进行了解耦。比如动作定义为接口&#xff0c;具体做什么动作 由实现动作接口的类来具体描述。 面向…

C# Types Type Members

http://blog.tangcs.com/2008/03/04/csharp-types-and-type-members/转载于:https://www.cnblogs.com/WarrenTang/archive/2008/03/04/1089628.html

Vue项目中自动将px转换为rem

一、配置与安装步骤&#xff1a; 1、在 Vue 项目的 src 文件夹下创建一个 config 文件夹&#xff1a; 2、在 config 文件夹中创建 rem.js&#xff1a; 3、将以下代码复制到 rem.js 中&#xff1a; // 基准大小 const baseSize 32 // 设置 rem 函数 function setRem () {// 当前…

开通博客啦!!

欢迎大家多多交流&#xff01; ——吃翔翔啊 转载于:https://www.cnblogs.com/chixiangxiang/p/11285295.html

beijing olympics - a travesty

来源:http://www.goaround.org/travel-asia/247473.htm Q:Dont watch it at all.If enough of us dont then the big advertisers may think twice before paying for time during the second week of a televised event from a country that has an unacceptable level of cen…

MySQL8.0.19下载安装及配置详细步骤

下载&#xff1a; 软件下载地址&#xff1a;https://www.mysql.com/downloads/ 进入主页后下滑见 然后点击下图的MySQL Community Server 进入之后&#xff0c;点击Download进行下载 进入Download之后&#xff0c;点击No thanks, just start my download&#xff08;无需注…

如何编写自定义的Web控件

建一个自定义的Web控件MyContro的步骤:1)引用using System;using System.IO;using System.Drawing;using System.Web.UI;using System.Web.UI.WebControls;using System.ComponentModel;2)保证MyContro是从WebControl继承的。public class MyControl:WebControl3)重写下面两个函…

解决[ERROR] [MY-013276] [Server] Failed to set datadir to ‘F:\Mysql\mysql-8.0.19-winx64\data\‘ (OS er

解决[ERROR] [MY-013276] [Server] Failed to set datadir to ‘F:\Mysql\mysql-8.0.19-winx64\data’ (OS errno: 2 - No such file or directory)报错问题 输入&#xff1a;mysqld --initialize --usermysql --console 如下图&#xff1a; 然后输入mysqld -install&#xff…

DataTable操作相关实例

代码 publicDataSet GetChildDepartmentsByUserId(Guid userId) { DataSet ds newDataSet(); try{ OrgChartDB.OrgChart_PermissionDataTable pdt permissionTableAdapter.GetDataByUserId(userId); for(inti 0; …

修改mysql密码时遇见ERROR 1064 (42000) You have an error in your SQL syntax; check the manual that correspo

修改mysql密码时遇见ERROR 1064 (42000) You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘password(‘123456’)’ at line 1报错 如下图&#xff1a; 这个句子翻译过来的意思是…