系统分析与设计Lesson7作业

个人作业

领域建模

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

    • 按 Task2 要求,请使用工具 UMLet,截图格式务必是 png 并控制尺寸。
    • 说明:请不要受 PCMEF 层次结构影响。你需要识别实体(E)和 中介实体(M,也称状态实体)。
      • 在单页面应用(如 vue)中,E 一般与数据库构建有关, M 一般与 store 模式 有关。
      • 在 java web 应用中,E 一般与数据库构建有关, M 一般与 session 有关。
        DomainModel

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

    • 按 Task 3 要求,给出系统的 E-R 模型(数据逻辑模型)。

      使用MySQL workbench画系统的E-R模型图:
      E-R_Model

    • 导出 Mysql 物理数据库的脚本。
-- MySQL Script generated by MySQL Workbench
-- Sun Apr 29 20:29:38 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`.`Customer`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`Customer` (
  `Customer_ID` INT NOT NULL,
  `Name` VARCHAR(45) NOT NULL,
  `EmailAddress` VARCHAR(45) NOT NULL,
  PRIMARY KEY (`Customer_ID`),
  UNIQUE INDEX `Customer_ID_UNIQUE` (`Customer_ID` ASC))
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`ShoppingBasket`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`ShoppingBasket` (
  `ShoppingBasket_ID` INT NOT NULL,
  `Customer_Customer_ID` INT NOT NULL,
  `Info` VARCHAR(45) NOT NULL,
  PRIMARY KEY (`ShoppingBasket_ID`, `Customer_Customer_ID`),
  UNIQUE INDEX `ShoppingBasket_ID_UNIQUE` (`ShoppingBasket_ID` ASC),
  INDEX `fk_ShoppingBasket_Customer_idx` (`Customer_Customer_ID` ASC),
  CONSTRAINT `fk_ShoppingBasket_Customer`
    FOREIGN KEY (`Customer_Customer_ID`)
    REFERENCES `mydb`.`Customer` (`Customer_ID`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`Reservation`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`Reservation` (
  `Reservation_ID` INT NOT NULL,
  `ShoppingBasket_ShoppingBasket_ID` INT NOT NULL,
  `Check-in Date` DATE NOT NULL,
  `Check-out Date` DATE NOT NULL,
  `Price` INT NOT NULL,
  `Note` VARCHAR(45) NULL,
  PRIMARY KEY (`Reservation_ID`, `ShoppingBasket_ShoppingBasket_ID`),
  UNIQUE INDEX `Reservation_ID_UNIQUE` (`Reservation_ID` ASC),
  INDEX `fk_Reservation_ShoppingBasket1_idx` (`ShoppingBasket_ShoppingBasket_ID` ASC),
  CONSTRAINT `fk_Reservation_ShoppingBasket1`
    FOREIGN KEY (`ShoppingBasket_ShoppingBasket_ID`)
    REFERENCES `mydb`.`ShoppingBasket` (`ShoppingBasket_ID`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`Address`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`Address` (
  `Address_ID` INT NOT NULL,
  `Country` VARCHAR(45) NOT NULL,
  `Region` VARCHAR(45) NOT NULL,
  `City` VARCHAR(45) NOT NULL,
  `Town` VARCHAR(45) NOT NULL,
  `Code` INT NOT NULL,
  UNIQUE INDEX `Address_ID_UNIQUE` (`Address_ID` ASC),
  PRIMARY KEY (`Address_ID`))
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`Hotel`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`Hotel` (
  `Hotel_ID` INT NOT NULL,
  `Address_Address_ID` INT NOT NULL,
  `name` VARCHAR(45) NOT NULL,
  `address` VARCHAR(45) NOT NULL,
  `star` INT NOT NULL,
  `hot_index` FLOAT NOT NULL,
  `Info` VARCHAR(45) NULL,
  PRIMARY KEY (`Hotel_ID`, `Address_Address_ID`),
  UNIQUE INDEX `Hotel_ID_UNIQUE` (`Hotel_ID` ASC),
  INDEX `fk_Hotel_Address1_idx` (`Address_Address_ID` ASC),
  CONSTRAINT `fk_Hotel_Address1`
    FOREIGN KEY (`Address_Address_ID`)
    REFERENCES `mydb`.`Address` (`Address_ID`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`Room`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`Room` (
  `Room_ID` INT NOT NULL,
  `Reservation_Reservation_ID` INT NOT NULL,
  `Hotel_Hotel_ID` INT NOT NULL,
  `num` INT NOT NULL,
  `isAvailable` TINYINT NOT NULL,
  `price` INT NOT NULL,
  `type` VARCHAR(45) NOT NULL,
  PRIMARY KEY (`Room_ID`, `Reservation_Reservation_ID`, `Hotel_Hotel_ID`),
  UNIQUE INDEX `Room_ID_UNIQUE` (`Room_ID` ASC),
  INDEX `fk_Room_Reservation1_idx` (`Reservation_Reservation_ID` ASC),
  INDEX `fk_Room_Hotel1_idx` (`Hotel_Hotel_ID` ASC),
  CONSTRAINT `fk_Room_Reservation1`
    FOREIGN KEY (`Reservation_Reservation_ID`)
    REFERENCES `mydb`.`Reservation` (`Reservation_ID`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_Room_Hotel1`
    FOREIGN KEY (`Hotel_Hotel_ID`)
    REFERENCES `mydb`.`Hotel` (`Hotel_ID`)
    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;
  • 简单叙说 数据库逻辑模型 与 领域模型 的异同。

    相同点:都反映了实体之间的关系,定义了实体名和相关属性。

    不同点:
    • 领域模型更偏向相关业务概念,来源于相关业务用例的描述,可以帮助更好地理解业务需求。
    • 数据库逻辑模型更偏向于开发者,考虑了系统数据的存储,着重于系统的实现,考虑实体间的约束关系,是领域模型的细化。
资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值