【系统分析与设计】作业四

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

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

    说明:请不要受 PCMEF 层次结构影响。你需要识别实体(E)和 中介实体(M,也称状态实体)
    在单页面应用(如 vue)中,E 一般与数据库构建有关, M 一般与 store 模式 有关
    在 java web 应用中,E 一般与数据库构建有关, M 一般与 session 有关
    

这里写图片描述

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

  • 按 Task 3 要求,给出系统的 E-R 模型(数据逻辑模型)
  • 导出 Mysql 物理数据库的脚本
  • 简单叙说 数据库逻辑模型 与 领域模型 的异同

ER模型:
这里写图片描述

MYSQL脚本:

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';

CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci ;
USE `mydb` ;

-- -----------------------------------------------------
-- Table `mydb`.`customer`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `mydb`.`customer` (
  `id` INT UNSIGNED NOT NULL ,
  `name` VARCHAR(20) NOT NULL ,
  `phone` VARCHAR(20) NOT NULL ,
  `email` VARCHAR(20) NOT NULL ,
  PRIMARY KEY (`id`) ,
  UNIQUE INDEX `id_UNIQUE` (`id` ASC) )
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`hotel`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `mydb`.`hotel` (
  `id` INT UNSIGNED NOT NULL ,
  `name` VARCHAR(45) NOT NULL ,
  `location` VARCHAR(45) NOT NULL ,
  PRIMARY KEY (`id`) ,
  UNIQUE INDEX `id_UNIQUE` (`id` ASC) )
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`room`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `mydb`.`room` (
  `number` INT UNSIGNED NOT NULL ,
  `type` VARCHAR(20) NOT NULL ,
  `isRented` TINYINT(1) NOT NULL ,
  PRIMARY KEY (`number`) ,
  UNIQUE INDEX `number_UNIQUE` (`number` ASC) )
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`hotel_room`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `mydb`.`hotel_room` (
  `hotel_id` INT UNSIGNED NOT NULL ,
  `room_number` INT UNSIGNED NOT NULL ,
  PRIMARY KEY (`hotel_id`, `room_number`) ,
  UNIQUE INDEX `hotel_id_UNIQUE` (`hotel_id` ASC) ,
  UNIQUE INDEX `room_number_UNIQUE` (`room_number` ASC) ,
  CONSTRAINT `fk_hotel`
    FOREIGN KEY (`hotel_id` )
    REFERENCES `mydb`.`hotel` (`id` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_room`
    FOREIGN KEY (`room_number` )
    REFERENCES `mydb`.`room` (`number` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`payment`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `mydb`.`payment` (
  `id` INT UNSIGNED NOT NULL ,
  `paidway` VARCHAR(45) NOT NULL ,
  `price` FLOAT UNSIGNED NOT NULL ,
  PRIMARY KEY (`id`) ,
  UNIQUE INDEX `id_UNIQUE` (`id` ASC) )
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`reservation`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `mydb`.`reservation` (
  `id` INT UNSIGNED NOT NULL ,
  `start_time` DATETIME NOT NULL ,
  `residence_time` DATETIME NOT NULL ,
  `hotel_id` INT UNSIGNED NOT NULL ,
  `room_number` INT UNSIGNED NOT NULL ,
  `customer_id` INT UNSIGNED NOT NULL ,
  `imfomations` TEXT NULL ,
  `payment_id` INT UNSIGNED NOT NULL ,
  PRIMARY KEY (`id`) ,
  UNIQUE INDEX `id_UNIQUE` (`id` ASC) ,
  UNIQUE INDEX `hotel_id_UNIQUE` (`hotel_id` ASC) ,
  UNIQUE INDEX `room_number_UNIQUE` (`room_number` ASC) ,
  UNIQUE INDEX `customer_id_UNIQUE` (`customer_id` ASC) ,
  UNIQUE INDEX `payment_id_UNIQUE` (`payment_id` ASC) ,
  CONSTRAINT `fk_hotel`
    FOREIGN KEY (`hotel_id` )
    REFERENCES `mydb`.`hotel_room` (`hotel_id` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_room`
    FOREIGN KEY (`room_number` )
    REFERENCES `mydb`.`hotel_room` (`room_number` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_payment`
    FOREIGN KEY (`payment_id` )
    REFERENCES `mydb`.`payment` (`id` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_customer`
    FOREIGN KEY (`customer_id` )
    REFERENCES `mydb`.`customer` (`id` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;

USE `mydb` ;


SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;

ER模型 与 领域模型 的异同:

E-R Model是属于数据建模的范畴,E-R Model是数据模型的一种表现形式(数据建模不只是E-R Model一种表现形式) ,E-R Model以数据为中心,关注的是对象的实体和关系,建模时并不考虑Entity的行为。在E-R概念模型的基础上可以建立“关系数据模型”进而推导出“物理数据模型”,这是一条以E-R Model为起始的数据建模的路线。

领域模型可以被看作是一个系统的概念模型,用于以可视化的形式描述系统中的各个实体及其之间的关系。领域模型记录了一个系统中的关键概念和词汇表,显示出了系统中的主要实体之间的关系,并确定了它们的重要的方法和属性。因此,对应于用例所描述的动态视图,领域模型提供了一种对整个系统的结构化的视图。领域模型的一个好处是描述并限制了系统边界。

总之,领域模型可以使用ER模型来表示,但ER模型对系统的刻画更具体,而领域模型比较抽象。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值