个人作业

领域建模

a. 阅读 Asg_RH 文档,按用例构建领域模型。

  • 按 Task2 要求,请使用工具 UMLet,截图格式务必是 png 并控制尺寸

    • 说明:请不要受 PCMEF 层次结构影响。你需要识别实体(E)和 中介实体(M,也称状态实体)

      • 在单页面应用(如 vue)中,E 一般与数据库构建有关, M 一般与 store 模式 有关
      • 在 java web 应用中,E 一般与数据库构建有关, M 一般与 session 有关

b. 数据库建模(E-R 模型)

  • 按 Task 3 要求,给出系统的 E-R 模型(数据逻辑模型)
  • 建模工具 PowerDesigner(简称PD) 或开源工具 OpenSystemArchitect
  • 不负责的链接 http://www.cnblogs.com/mcgrady/archive/2013/05/25/3098588.html
  • 导出 Mysql 物理数据库的脚本
  • 简单叙说 数据库逻辑模型 与 领域模型 的异同

-- MySQL Script generated by MySQL Workbench
-- Sun Apr 29 15:44:19 2018
-- Model: New Model Version: 1.0
-- MySQL Workbench Forward Engineering SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL,ALLOW_INVALID_DATES'; -- -----------------------------------------------------
-- Schema mydb
-- ----------------------------------------------------- -- -----------------------------------------------------
-- Schema mydb
-- -----------------------------------------------------
CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET utf8 ;
USE `mydb` ; -- -----------------------------------------------------
-- Table `mydb`.`Destination`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `mydb`.`Destination` ; CREATE TABLE IF NOT EXISTS `mydb`.`Destination` (
`DestinationID` INT NOT NULL,
`DestinationName` VARCHAR(45) NULL,
`DestinationType` VARCHAR(45) NULL,
PRIMARY KEY (`DestinationID`))
ENGINE = InnoDB; -- -----------------------------------------------------
-- Table `mydb`.`Hotel`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `mydb`.`Hotel` ; CREATE TABLE IF NOT EXISTS `mydb`.`Hotel` (
`HotelID` INT NOT NULL,
`HotelName` VARCHAR(45) NULL,
`star rating` INT NULL,
`Min. stay` INT NULL,
PRIMARY KEY (`HotelID`),
CONSTRAINT `DestinationID`
FOREIGN KEY ()
REFERENCES `mydb`.`Destination` ()
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB; -- -----------------------------------------------------
-- Table `mydb`.`Room`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `mydb`.`Room` ; CREATE TABLE IF NOT EXISTS `mydb`.`Room` (
`RoomID` INT NOT NULL,
`price` FLOAT NULL,
`RoomType` VARCHAR(45) NULL,
`RoomDate` DATE NULL,
`isAvailable` TINYINT NULL,
`No. of adults` INT NULL,
`No. of children` INT NULL,
PRIMARY KEY (`RoomID`),
CONSTRAINT `HotelID`
FOREIGN KEY ()
REFERENCES `mydb`.`Hotel` ()
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB; -- -----------------------------------------------------
-- Table `mydb`.`Customer`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `mydb`.`Customer` ; CREATE TABLE IF NOT EXISTS `mydb`.`Customer` (
`CustomerID` INT NOT NULL,
`CustomerName` VARCHAR(45) NULL,
`CustomerEmail` VARCHAR(45) NULL,
PRIMARY KEY (`CustomerID`))
ENGINE = InnoDB; -- -----------------------------------------------------
-- Table `mydb`.`Reservation`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `mydb`.`Reservation` ; CREATE TABLE IF NOT EXISTS `mydb`.`Reservation` (
`ReservationID` INT NOT NULL,
`check-in date` DATE NULL,
`check-out date` DATE NULL,
`payment option` INT NULL,
`booking details` VARCHAR(45) NULL,
`canSmoke` TINYINT NULL,
`special requirement` VARCHAR(45) NULL,
PRIMARY KEY (`ReservationID`),
CONSTRAINT `CustomerID`
FOREIGN KEY ()
REFERENCES `mydb`.`Customer` ()
ON DELETE NO ACTION
ON UPDATE NO ACTION,
CONSTRAINT `RoomID`
FOREIGN KEY ()
REFERENCES `mydb`.`Room` ()
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB; -- -----------------------------------------------------
-- Table `mydb`.`Payment`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `mydb`.`Payment` ; CREATE TABLE IF NOT EXISTS `mydb`.`Payment` (
`PaymentID` INT NOT NULL,
`isSuccessful` TINYINT NULL,
PRIMARY KEY (`PaymentID`),
CONSTRAINT `ReservationID`
FOREIGN KEY ()
REFERENCES `mydb`.`Reservation` ()
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB; SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;

数据库逻辑模型和领域模型的异同:

二者都被用于业务的分析,从中抽象出具体的逻辑和实体,从而帮助人们更好地认识业务本身。不同的地方在于领域模型更注重全面地认识问题,并不仅仅是面向开发。而数据库逻辑模型更注重在开发过程中的实际效用,针对的是数据库中实体之间的逻辑的研究。对于无必要储存于数据库中的实体,数据库逻辑模型并不研究。

系统分析与设计HW5的更多相关文章

  1. FPGA最小系统分析与电路设计

    <FPGA最小系统分析与电路设计> 部分节选自<FPGA应用开发入门与典型.pdf > FPGA最小系统包括:FPGA芯片.下载电路.外部时钟.复位电路和电源. 如果使用NIO ...

  2. 系统分析与设计个人作业:WordCount

    本次作业gitee地址:https://gitee.com/ackary/WordCount 一.项目简介 1.基础功能 基础功能部分主要实现的功能是统计一个程序设计语言源文件的字符数.单词数.行数, ...

  3. 文献综述十六:基于UML的中小型超市管理系统分析与设计

    一.基本信息 标题:基于UML的中小型超市管理系统分析与设计 时间:2016 出版源:Journal of Xiangnan University 文件分类:uml技术系统的研究 二.研究背景 开发一 ...

  4. 系统分析与设计lesson6

    | 分类 作业  | 1.用例建模 a. 阅读 Asg_RH 文档,绘制用例图. 按 Task1 要求,请使用工具 UMLet,截图格式务必是 png 并控制尺寸 b. 选择你熟悉的定旅馆在线服务系统 ...

  5. 奖学金评分系统(系统分析与设计版与Delphi实现代码)

    一.系统规划 1.1 项目背景介绍 在奖学金评比过程中,学生综合测评是学校普遍采用的评比手段.对学生实施综合素质测评的目的在于正确评价学生的综合素质,为评奖学金提供依据,实现学生教育管理工作的标准化. ...

  6. 系统分析与设计 homework2

    1. 简述瀑布模型.增量模型.螺旋模型(含原型方法)的优缺点. 瀑布模型 优点: 降低了软件开发的复杂度,提高软件开发过程中的透明性,提高软件开发的可管理性. 为项目提供了按阶段划分的检查点. 当前一 ...

  7. 系统分析与设计HW2

    简答题 1. 简述瀑布模型.增量模型.螺旋模型(含原型方法)的优缺点. 瀑布模型 优点: 定义了软件开发基本流程与活动. 为项目提供了按阶段划分的检查点. 当前一阶段完成后,只需关注后续阶段. 缺点: ...

  8. WordCount系统分析与设计作业

    Gitee项目地址 https://gitee.com/gitdq/homework psp表 PSP2.1 PSP阶段 预估耗时 (分钟) 实际耗时 (分钟) Planning 计划 10 10 · ...

  9. 系统分析与设计 homework-1

    1.软件工程的定义 软件工程是将系统化.规范化.可度量的方法应用于软件的开发.运营和维护上,也就是将工程方法应用于软件上,并对这些方法的研究. 2.软件危机(software crisis) 软件危机 ...

随机推荐

  1. python-scp-上传文件到服务器

    python中使用scp,将文件上传到服务器 def ssh_scp_put(ip, username, password, local_file, remote_path): "" ...

  2. inittab - 与 sysv 兼容的 init 进程使用的初始化文件格式

    描述 inittab 文件描述在系统引导及通常的操作期间, 都启动哪些进程 (比如 /etc/init.d/boot, /etc/init.d/rc, getty 等等). Init(8) 讨论有关 ...

  3. 测试 windows 发布日志

    <script>alert("hellow world")</script>

  4. horizon服务

    一.horizon 介绍: 理解 horizon Horizon 为 Openstack 提供一个 WEB 前端的管理界面 (UI 服务 )通过 Horizone 所提供的 DashBoard 服务 ...

  5. Kong组件构成及使用

    Service: Service 顾名思义,就是我们自己定义的上游服务,通过Kong匹配到相应的请求要转发的地方 Service 可以与下面的Route进行关联,一个Service可以有很多Route ...

  6. 【LuoguP5206】[WC2019] 数树

    题目链接 题意 定义 \(F(T_1,T_2)=y^{n-common}\) 其中 \(common\) 为两棵树 \(T_1,T_2\) 的公共边条数. 三种问题 1.给定 \(T_1,T_2\) ...

  7. R中的常用命令(持续更新)

    (1)工作环境 #Ctrl+L键:清屏#Ctrl+Shift+C键:注释.取消注释(仅在RStudio中)(可以多行) rm(变量) #清除某变量 ls() #列出内存中的变量 rm(list=ls( ...

  8. Comet OJ - Contest #14题解

    Contest14的本质:区间覆盖+Tarjan( A 把距离公式两边平方即可 注意要long long code #include <algorithm> #include <io ...

  9. SpringApplication.run 做了哪些事?

    SpringApplication.run一共做了两件事,分别是 创建SpringApplication对象 利用创建好的SpringApplication对象,调用run方法论 结论: 面试官: 我 ...

  10. CentOS7安装codeblocks

    1.yum -y install epel-release 2.yum clean all && yum makecache 3.yum -y install gtk2-devel c ...