根据数据库设计开发一套通用的电子商务平台

news/2024/9/18 12:37:56/ 标签: 软件工程, 软件构建, 数据库, ORM

目录

案例

【题目】

【问题 1】(9 分)

【问题 2】(9 分)

【问题 3】(7 分)

【答案】

【问题 1】解析

【问题 2】解析

【问题 3】解析

相关推荐


案例

        阅读以下关于数据库设计的叙述,在答题纸上回答问题 1 至问题 3。

【题目】

        某制造企业为拓展网上销售业务,委托某软件企业开发一套电子商务网站。初期仅解决基本的网上销售、订单等功能需求。该软件企业很快决定基于。NET 平台和 SQLServer 数据库进行开发,但在数据库访问方式上出现了争议。王工认为应该采用程序在线访问的方式访问数据库:而李工认为本企业内部程序员缺乏数据库开发经验,而且应用筒单,应该采用ORM(对象关系映射)方式。最终经过综合考虑,该软件企业采用了李工的建议。

        随着业务的发展,该电子商务网站逐渐发展成一个通用的电子商务平台,销售多家制造企业的产品,电子商务平台的功能也日益复杂。目前急需对该电子商务网站进行改造,以支持对多种异构数据库平台的数据访问,同时满足复杂的数据管理需求。该软件企业针对上述需求,对电子商务网站的架构进行了重新设计,新增加了数据访问层,同时采用工厂设计模式解决异构数据库访问的问题。新设计的系统架构如图 4-1 所示。

【问题 1】(9 分)

        请用 300 字以内的文字分别说明数据库程序在线访问方式和 ORM 方式的优缺点,说明该软件企业采用 ORM 的原因。

【问题 2】(9 分)

        请用 100 宇以内的文字说明新体系架构中增加数据访问层的原因。请根据图 4-1 所示,填写图中空白处(1)-(3)

【问题 3】(7 分)

        应用程序设计中,数据库访问需要良好的封装性和可维护性,因此经常使用工厂设计模式来实现对数据库访问的封装。请解释工厂设计模式,并说明其优点和应用场景:请解释说明工厂模式在数据访问层中的应用。

【答案】

【问题 1】解析

        数据访问层常见的模式有 5 种 分别是:在线访问、Data Access Object、Data Transfer Object、离线数据模式、对象/关系映射(Object/Relation Mapping)。

        ORM,即 Object-Relationl Mapping,它在关系型数据库和对象之间作一个映射,这样,我们在具体的操作数据库的时候,就不需要再去和复杂的 SQL 语句打交道,只要像平时操作对象一样操作即可。

        数据库程序在线访问方式优点:
        1、性能比 ORM
        2、可以处理复杂查询语句
        数据库程序在线访问方式缺点:
        (1)要求程序员懂 SQL 语句
        (2)修改与维护相对困难
        ORM 优点:
        (1)使用 ORM 可以大大降低学习和开发成本。
        (2)程序员不用再写 SQL 来进行数据库操作。
        (3)减少程序的代码量。
        (4)降低由于 SQL 代码质量差而带来的影响。
        ORM 缺点:
        (1)不太容易处理复杂查询语句。
        (2)性能较直接用 SQL 差。
        本题中的场景之所以选择 ORM,主要考虑的是程序缺数据库开发经验,这样 SQL 语句质量有很大风险。同时学习成本很高。此外应用简单,不也担心 ORM 对性能的影响。

【问题 2】解析

        增加数据访问层的原因:
        由于涉及到多种异构数据库平台,数据访问复杂性增加,不宜与业务逻辑混合在一起(题目中粗体标出)。
        数据管理变复杂之后,需要使用的代码量增加,分单独层次有利于让逻辑更清晰。
        业务逻辑应以相同的方式应对异构的数据库,此时需要单独的数据访问层屏蔽差异性。
        (1)-(3)空白处分别问:(1)业务组件、(2)数据访问接口、(3)数据访问工厂。

【问题 3】解析

        工厂模式分抽象工厂与工厂方法,题目中的场景适合采用抽象工厂设计模式。
        抽象工厂设计模式提供一个接口,可以创建一系列相关或相互依赖的对象,而无需指定它们具体的类。其优点是可以非常方便的创建一系列的对象,其使用场景也是创建系列对象的情况。在本题中,可以针对 Oracle、MySQL、SQLServer 分别建立抽象工厂,若指定当前工厂为 Oracle 工厂,则创建出来的数据库连接,数据集等一系列的对象都是符合 Oracle 操作要求的。这样便于数据库之间的切换。

相关推荐

【系统架构设计师】十九、层次式架构设计理论与实践②-CSDN博客文章浏览阅读926次,点赞18次,收藏13次。数据访问模式有 5 种,分别是:在线访问、Data Access Object、Data Transfer Object、离线数据模式、对象/关系映射(Object/Relation Mapping)。数据库设计与XML 设计融合:XML 正在成为Internet上数据描述和交换的标准,并且将来会代替 HTML 而成为 Web 上保存数据的主要格式。https://shuaici.blog.csdn.net/article/details/140689664设计模式之创建型模式-CSDN博客文章浏览阅读1.8k次,点赞3次,收藏4次。本文详细介绍了创建型设计模式,包括抽象工厂、建造者、工厂方法、原型和单例模式。这些模式提高了代码的灵活性,降低了对象创建的复杂性。抽象工厂模式用于创建相关对象家族,建造者模式关注复杂对象的构建过程,工厂方法模式让类的实例化推迟到子类,原型模式通过对象复制创建新实例,单例模式确保一个类只有一个实例。了解并合理运用这些模式能提升软件设计的质量和可维护性。https://shuaici.blog.csdn.net/article/details/116521002


http://www.ppmy.cn/news/1516407.html

相关文章

河南萌新联赛2024第(六)场:郑州大学(补题ABCDFGIL)

文章目录 河南萌新联赛2024第(六)场:郑州大学A 装备二选一(一)简单介绍:思路:代码: B 百变吗喽简单介绍:思路:代码: C 16进制世界简单介绍&#x…

es相关概念、索引操作(相当于mysql中的数据库操作)

文章目录 1、概念2、索引操作(index)2.1、查询索引(数据库)2.2、创建索引(数据库)2.3、查看单个索引(数据库)2.4、删除索引(数据库) 1、概念 RDBMSesMongoDB…

Manim实现目标的移动和出现速度控制

一,介绍 缓动函数 自定义参数随时间变化的速率。 现实生活中,物体并不是突然启动或者停止, 当然也不可能一直保持匀速移动。就像我们 打开抽屉的过程那样,刚开始拉的那一下动作很快, 但是当抽屉被拉出来之后我们会不自…

【操作系统】实验:进程死锁

目录 一、实验目的 二、实验要求 三、实验步骤 四、核心代码 五、记录与处理 六、思考 七、完整报告和成果文件提取链接 一、实验目的 1掌握死锁的基本概念; 2理解死锁的必要条件; 3理解避免死锁的方法、安全状态等重要概念; 4了解银…

Windows环境如何安装maven并配置IDEA

运行Springboot项目时,出现了依赖错误,最后排查可能是maven安装出错了。 MAVEN版本要和IDEA版本对应,maven发行版本不能比idea版本高,可以在idea查看内置的maven版本。 点击 File–>Settings,在设置页面搜索maven,如…

2024牛客暑期多校训练营7 D.Interval Selection(异或哈希+双指针)

原题链接:D.Interval Selection 题目大意: 给你一个长度为 n n n 的数组 a a a,定义一个区间 [ l , r ] [l,r] [l,r] 内的连续子数组为好的,当且仅当这个子数组内的所有元素 a l , a l 1 , . . . , a r a_{l},a_{l1},...,a_{…

虚幻5|暴击攻击和释放技能,造成伤害

玩家数据的Actor组件制作:虚幻5|制作玩家血量,体力-CSDN博客 造成伤害时,显示暴击及暴击字体颜色和未暴击的字体颜色,还有释放技能连击 一.编辑暴击数据 1.打开之前创建的玩家数据Actor组件 创建一个浮点变量,命名…

Python实现贪心算法

目录 贪心算法简介贪心算法的基本思想贪心算法的应用场景活动选择问题 Python实现活动选择问题代码解释活动选择问题的解贪心算法的正确性分析贪心算法的其他应用贪心算法的局限性贪心算法的优化与变种总结 贪心算法简介 贪心算法(Greedy Algorithm)是一…

10天速通Tkinter库——Day7:主菜单及图鉴

本篇博客我将介绍Tkinter实践项目《植物杂交实验室》中的杂交实验室主菜单、基础植物图鉴、杂交植物图鉴、杂交植物更多信息四个页面的制作。 它们作为主窗口的子页面实例,除了继承主窗口的基础设置(如图标、标题、尺寸等等)、还可以使用主窗…

使用C++开发黑神话悟空类似3A如何避免内存泄漏

智能指针:使用C11或更高版本中的智能指针(如std::unique_ptr、std::shared_ptr和std::weak_ptr)来自动管理内存。这些智能指针在超出作用域时会自动释放它们所管理的内存。 RAII(Resource Acquisition Is Initialization&#xf…

Java开发程序员职业发展路径

入行阶段:后端 3年 目标 在这一阶段,你将专注于后端开发,特别是Java编程语言及其相关技术栈。 主要任务和技能 掌握Java基础: 理解Java语言的核心概念,如OOP(面向对象编程)、数据结构、算法等。学习后端…

【Rust练习】10.元组

练习题来自:https://practice-zh.course.rs/compound-types/tuple.html 1 元组中的元素可以是不同的类型。元组的类型签名是 (T1, T2, …), 这里 T1, T2 是相对应的元组成员的类型. fn main() {let _t0: (u8,i16) (0, -1);// 元组的成员还可以是一个元组let _t1:…

相关性分析

斯皮尔曼、皮尔逊、肯德尔、点双列相关分析、偏相关分析、距离相关分析、双变量回归分析和互信息。 特性斯皮尔曼相关分析(Spearman Correlation)皮尔逊相关分析(Pearson Correlation)肯德尔相关分析(Kendall’s Tau&…

华为OD题目 csv格式的数据 字符串 用C没写出来

这题对于嵌入式mcu的人来说,太难为了。不想解了,烂摆。有心情再说把。 将一个csv格式的数据文件中包含有单元格引用的内容替换为对应单元格内容的实际值。 Comma seprated values(CSV)逗号分隔值,csv格式的数据文件使用…

nodemon学习(一)简介、安装、配置、使用

nodemon用来监视node.js应用程序中的任何更改并自动重启服务,非常适合用在开发环境中。以前,我们开发一个node后端服务时,每次更改文件,均需重启一下,服务才能生效。这使我们的开发效率降低了很多。nodemon的出现,可以…

Catf1ag CTF Crypto(六)

前言 Catf1agCTF 是一个面向所有CTF(Capture The Flag)爱好者的综合训练平台,尤其适合新手学习和提升技能 。该平台由catf1ag团队打造,拥有超过200个原创题目,题目设计注重知识点的掌握,旨在帮助新手掌握C…

ffmpeg.exe命令行常见应用

基本转换: ffmpeg -i input.mp4 output.avi将input.mp4文件转换为output.avi文件。 提取音频: ffmpeg -i input.mp4 -vn output.mp3从input.mp4文件中提取音频并保存为output.mp3文件。 视频剪辑: ffmpeg -i input.mp4 -ss 00:00:30 -t 00:…

深入探讨Java多线程

我的主页:2的n次方_ 1. 多线程的概念 多线程是指在同一个程序中同时执行多个线程的技术。线程是操作系统能够独立调度和执行的最小单位。在Java中,线程由Thread类来表示,所有的线程都是通过这个类或其子类来创建和控制的。通过合理的多线…

codetop标签动态规划大全C++讲解(上)!!动态规划刷穿地心!!学吐了家人们o(╥﹏╥)o

主要供自己回顾学习,会持续更新,题源codetop动态规划近半年 1.零钱兑换2.零钱兑换II3.面试题08.11.硬币4.单词拆分5.最长递增子序列6.最长递增子序列的个数7.得到山形数组的最少删除次数8.最长公共子序列9.最长重复子数组10.最长等差数列11.最大子数组和…

Docker数据卷使用手册

目录 目标 前言 概念 官方文档 匿名卷(Anonymous Volumes) 简介 案例 命名卷(Named Volumes) 简介 案例 目标 掌握Volume命令通过演示案例,理解数据卷种类与各自的用途。 前言 我们在很多网上教程上可以看到…