




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第8章 使用三层结构开发数据库应用系统技能目标使用三层结构开发项目体会到使用三层结构开发的优势为什么需要三层结构服务员只管接待客人厨师只管烹炒客人要的美食采购员只管按客人需求采购肉,海鲜,蔬菜他们各负其责共同协作为客人提供美食顾客服务员厨师采购员饭店饭店服务员厨师采购员为什么需要三层结构离职、请假离职、请假其他服其他服务员代替务员代替离职、请假离职、请假离职、请假离职、请假其他厨其他厨师代替师代替其他采其他采购员代替购员代替服务员厨师采购员为什么需要三层结构三层结构软件模型三层结构软件模型 表示层表示层 业务逻辑层业务逻辑层 数据访问层数据访问层 软件软件系统系统 饭店饭店 为什么需要三层结构
2、:登录实现部分:登录实现部分(LoginForm类类)代码代码我们从三方面对登录实现部分代码进行分析我们从三方面对登录实现部分代码进行分析1、界面控件数据绑定实现、界面控件数据绑定实现2、逻辑判断实现、逻辑判断实现3、数据库访问实现、数据库访问实现首先我们看一下界面部分的关键代码首先我们看一下界面部分的关键代码 为什么需要三层结构 / 登录登录 private void btnLogIn_Click(object sender, EventArgs e) /. if (ValidateInput() / 调用用户验证方法调用用户验证方法 isValidUser = ValidateUser(c
3、boLogInType.Text, txtLogInId.Text, txtLogInPwd.Text, ref message);/ 如果是合法用户,显示相应的窗体如果是合法用户,显示相应的窗体 /. 界面层实现界面层实现 为什么需要三层结构 public bool ValidateUser(string loginType, string loginId, string loginPwd, ref string message) int count = 0; / 数据库查询的结果数据库查询的结果 bool result = false; / 返回值,是否找到该用户返回值,是否找到该用户 /
4、 查询是否存在匹配的用户名和密码查询是否存在匹配的用户名和密码 if (loginType= “管理员管理员”) / 判断判断是否是是否是管理员用户管理员用户 /数据访问实现代码数据访问实现代码. else if (loginType = 学员学员) /数据访问实现代码数据访问实现代码. return result; 逻辑判逻辑判断实现断实现用户登录实现方法用户登录实现方法 为什么需要三层结构 public bool ValidateUser(string loginType, string loginId, string loginPwd, ref string message) /. /
5、查询是否存在匹配的用户名和密码查询是否存在匹配的用户名和密码/ 查询用查询用sql语句语句 string sql = string.Format( SELECT COUNT(*) FROM Admin WHERE LogInId=0 AND LogInPwd=1, txtLogInId.Text txtLogInPwd.Text );/./ 查询用查询用sql语句语句 string sql = string.Format( SELECT COUNT(*) FROM Student WHERE LogInId=0 AND LogInPwd=1,txtLogInId, txtLogInPwd);
6、管理员信息数据访问管理员信息数据访问 用户登录实现方法用户登录实现方法通过分析我们得到结论是?通过分析我们得到结论是? 学员信息数据访问学员信息数据访问为什么需要三层结构1、数据库访问和用户类型判断逻辑放在一起实现、数据库访问和用户类型判断逻辑放在一起实现2、用户界面层直接调用数据访问实现、用户界面层直接调用数据访问实现3、整个系统功能放在同一项目中实现、整个系统功能放在同一项目中实现结论是:结论是:从结论可知,我们开发的两层结构应用系统有哪些局限性?从结论可知,我们开发的两层结构应用系统有哪些局限性? 为什么需要三层结构两层结构:三层结构:用户界面用户界面业务逻辑业务逻辑数据访问数据访问两层
7、结构软件模型两层结构软件模型数据数据访问访问业务业务逻辑逻辑用户用户界面界面三层结构软件模型三层结构软件模型当数据库或当数据库或用户界面发用户界面发生改变时需生改变时需要重新开发要重新开发整个系统整个系统当数据库或当数据库或用户界面发用户界面发生改变时不生改变时不需要重新开需要重新开发,只做简发,只做简单调整即可单调整即可什么是三层结构表示层表示层 业务逻辑层业务逻辑层 数据访问层数据访问层 为用户提供为用户提供交互操作界面交互操作界面 负责关键业务的负责关键业务的处理和数据传递处理和数据传递 实现数实现数据库访问据库访问 服务员服务员 厨师厨师 采购员采购员 什么是三层结构表示层: 为用户提
8、供一种交互式操作界面为用户提供一种交互式操作界面 什么是三层结构业务逻辑层是表示层与数据访问层之间的桥梁,负责数据处理、传递。是表示层与数据访问层之间的桥梁,负责数据处理、传递。 用户请求数据用户请求数据用户请求数据用户请求数据/switch (type) case 管理员管理员: loginPwd = GetAdminLoginPwd(loginID); break; case 学员学员: loginPwd = GetStudentLoginPwd(loginID); break; / 什么是三层结构数据访问层用户请求数据用户请求数据ADO.NETSQL命令实现对数据的保存和读取操作实现对数
9、据的保存和读取操作 /.conn.Open();SqlDataReader objReader = objCommand.ExecuteReader();if (objReader.Read() studentlist.Add(objReaderLoginPwd); studentlist.Add(objReaderUserStateId); objReader.Dispose();conn.Close();/.什么是三层结构三层之间依赖关系表示层表示层业务逻辑层业务逻辑层数据访问层数据访问层什么是三层结构三层之间的数据传递方向业务逻辑层业务逻辑层数据访问层数据访问层表示层表示层客客户户请请求
10、求客客户户请请求求响响应应数数据据响响应应数数据据如何搭建三层结构 如何搭建表示层、业务逻辑层、数据访问层? 如何实现各层之间的相互依赖?要掌握这一切,我们将整个实现过程分为以下步骤要掌握这一切,我们将整个实现过程分为以下步骤 搭建三层结构步骤1、搭建表示层(创建一个、搭建表示层(创建一个Windows应用应用程序)程序)2、搭建业务逻辑层(、搭建业务逻辑层(类库类库)3、搭建数据访问层(、搭建数据访问层(类库类库)4、添加各层之间的相互依赖、添加各层之间的相互依赖 现在我们打开现在我们打开VS IDE环境逐层搭建三层结构环境逐层搭建三层结构 搭建表示层2、在弹出的、在弹出的“新建项目新建项目
11、“窗口中,选择窗口中,选择Windows应用程序应用程序选择选择语言语言种类种类项目类型项目类型创建解决方案创建解决方案输入项目名称输入项目名称MySchool选择项目选择项目生成路径生成路径1、文件、文件 新建新建 项目项目 :创建一个新项目:创建一个新项目搭建业务逻辑层2、在弹出的、在弹出的“新建项目新建项目”窗口中,选择类库窗口中,选择类库选择选择语言语言种类种类项目类型项目类型项目名称:项目名称:MySchoolBLL选择选择项目项目路径路径选择选择“添入解决方案添入解决方案”1、文件、文件 新建新建 项目项目 :创建一个新项目:创建一个新项目搭建数据访问层2、在弹出的、在弹出的“新建
12、项目新建项目“窗口中,选择类库窗口中,选择类库 选择选择语言语言种类种类项目类型项目类型项目名称:项目名称:MySchoolDAL选择选择项目项目路径路径选择选择“添入解决方案添入解决方案”如何将三层中各自独立的项目产生依赖如何将三层中各自独立的项目产生依赖1、文件、文件 新建新建 项目项目 :创建一个新项目:创建一个新项目 添加各层之间的相互依赖:添加表示层对业务逻辑层依赖:添加表示层对业务逻辑层依赖1、右键单击、右键单击“引用引用”选择选择“添加引用添加引用” 2、选择、选择“项目项目”,选中,选中“逻辑层逻辑层”单击单击 确定确定 添加业务逻辑层对数据访问层的依赖与此类似添加业务逻辑层对
13、数据访问层的依赖与此类似完成对逻完成对逻辑层的引用辑层的引用为什么需要实体类看“学员信息列表”它不具备它不具备OO的优点的优点实现数据检索比较繁琐、易出错实现数据检索比较繁琐、易出错它使数据结构暴露在业务逻辑层和表示层它使数据结构暴露在业务逻辑层和表示层为了消除以上局限性我们需要使用实体类为了消除以上局限性我们需要使用实体类DataSet解析实体对象解析实体对象构建实体对象构建实体对象返回行集返回行集为什么需要实体类处理窗体处理窗体表示层表示层表示层后台代码表示层后台代码业务逻辑层业务逻辑层数据访问层数据访问层数据库数据库用户请求用户请求传递参数传递参数展示数据展示数据返回返回请求数请求数据操
14、作据操作调用存储过程调用存储过程返回返回解析实体对象解析实体对象构建实体对象或集合构建实体对象或集合为什么需要实体类从OOP思想考虑 它是完全受控制的对象 它具有面向对象的基本特征 它可以自定义行为 它消除了关系数据和对象之间的差异 它为我们在关系数据库和对象之间架起一座桥梁它为我们在关系数据库和对象之间架起一座桥梁 什么是实体类管理员管理员数据表数据表简单地说就是描述一个业务实体的类,例如:管理员信息简单地说就是描述一个业务实体的类,例如:管理员信息 管理员信息管理员信息对应的实体类对应的实体类三层结构中的实体类:表示层如何使用实体类:表示层如何使用实体类 12三层结构中的实体类:业务逻辑层
15、如何使用实体类:业务逻辑层如何使用实体类 业务逻辑层业务逻辑层 实实体体对对象象实实体体对对象象12表示层表示层 数据访问层数据访问层 三层结构中的实体类:数据访问层如何使用实体类:数据访问层如何使用实体类 12完成本章任务的步骤实现业务实体层新增项目MySchoolModels添加其它项目对实体项目的引用添加数据表对应的实体类编写实体类设计用户界面实现数据访问层实现业务逻辑层实现表示层数据绑定实现业务实体层选择选择语言语言种类种类项目类型项目类型输入项目名称输入项目名称MySchoolModels选择项目选择项目生成路径生成路径在解决方案“MySchoolPro” 上单击右键选择“添加” 新
16、建项目实现业务实体层类名称类名称在 “MySchoolModels”项目上单击右键选择“添加” 新建项 依次添加“Admin.cs、Class.cs、Grade.cs”实现业务实体层它是业务的基础、数据传递的载体,它与其他项目的依赖关系是什么?它是业务的基础、数据传递的载体,它与其他项目的依赖关系是什么? 实体类实体类 编写实体类实现业务实体层表示层表示层业务实体业务实体业务逻辑业务逻辑数据访问层数据访问层 实现实现三层三层对业务实体的依赖对业务实体的依赖设计用户界面 3、按需求添加所需窗体,并编辑窗体按需求添加所需窗体,并编辑窗体 1 1、在、在“MySchool”项目上单击右键选择项目上单
17、击右键选择“添加添加” 新建项新建项 2、在、在“添加添加新项新项“对话框中选择对话框中选择”Windows 窗体窗体” 实现数据访问层 2、在、在“添加添加新项新项“对话框中选择对话框中选择”类类” 类名称类名称如何实现高效的数据访问呢?我们需要掌握如何实现高效的数据访问呢?我们需要掌握using语句的使用语句的使用 新增类有:新增类有:AdminService.csStudentService.cs 1、在、在“MySchoolDAL”项目上单击右键选择项目上单击右键选择“添加添加” 新建项新建项 实现数据访问层:用户登录用户登录 1、在数据访问实现类中引用业务实体项目命名空间、在数据访问
18、实现类中引用业务实体项目命名空间2、实例化、实例化SqlConnection对象,实现数据库连接对象,实现数据库连接3、实例化、实例化SqlCommand对象,执行对象,执行SQL命令命令4、实例化、实例化SqlDataReader对象,读取数据对象,读取数据5、使用实体类传递信息、使用实体类传递信息6、回顾、回顾List的使用的使用实现业务逻辑层 2、在、在“添加添加新项新项“对话框中对话框中 选择选择”类类” 类名称类名称新增类有:新增类有:LoginManager.cs如何实现业务逻辑功能?如何实现业务逻辑功能?1、在、在“MySchoolBLL”项目上单击右键选择项目上单击右键选择“添加添加” 新建项新建项 实现业务逻辑层:用户登录用户登录 1、回顾第二章的实现、回顾第二章的实现2、在业务逻辑处理类中引用数据访问层、业务实体层命名空间、在业务逻辑处理类中引用数据
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年通信接入设备项目提案报告
- 2025年血液制剂项目立项申请报告范文
- 2025贵州毕节医学高等专科学校第一批次“人才强市”暨高层次急需紧缺人才引进模拟试卷附答案详解(典型题)
- 合作项目质量与责任承诺书5篇
- 2025年嘉兴海宁市中心医院公开招聘高层次急需卫技人员4人考前自测高频考点模拟试题及参考答案详解
- 行业信誉铸就承诺书9篇
- 2025昆仑数智科技有限责任公司春季高校毕业生招聘15人考前自测高频考点模拟试题及答案详解(易错题)
- 2025年绍兴新昌县卫健系统第一次公开招聘编外人员6人模拟试卷及一套完整答案详解
- 作业保护设计印刷合同7篇
- 经济项目合作协议承诺书(7篇)
- 2025-2030中国饲用微生态制剂行业发展动态及未来前景展望报告
- 工程围墙销售方案(3篇)
- 中班美术:我设计的围巾
- 物流库区进出管理制度
- 中美大学技术转移模式与效率的深度剖析:基于多维度视角的比较研究
- 房屋共有份额协议书
- 人工智能辅助的核医学影像诊断系统-洞察阐释
- 外贸公司简介课件
- 电子商务跨境电商客户服务解决方案
- 加工终止合同协议书
- 2023产品质量监督抽查工作规范
评论
0/150
提交评论