HNU-数据库系统-实验3-数据库设计

数据库系统 课程实验3
数据库设计

计科210X 甘晴void 202108010XXX

目录

文章目录

  • 数据库系统 课程实验3<br>数据库设计
    • 实验目的
    • 实验内容
    • 实验重难点
    • 实验环境
    • 实验过程
      • (0)数据库需求描述
      • (1)数据库概念结构设计
        • E-R图
        • 实体
          • 图书馆library:
          • 图书book:
          • 出版社press:
          • 注册读者reader:
          • 访客visitor:
          • 管理员admin:
        • 关系
          • 借阅borrow
          • 查询query
        • 【初步使用PowerDesigner】
          • ①新建一个“概念模型”文件
          • ②使用工具框绘制实体并连接关系
          • ③编辑实体属性
          • ④编辑关系的特征
          • ⑤检查模型
        • 【操作】
      • (2)数据库逻辑结构设计
        • 【操作】
      • (3)数据库物理结构设计
        • 【操作】
      • (4)SQL语句生成
        • 【操作】
        • 代码
        • 验证
    • 参考文献
    • 实验感悟

实验目的

掌握数据库设计的基本方法及数据库设计工具。

实验内容

掌握数据库设计的基本步骤,包括数据库概念结构设计、逻辑结构设计,物理结构设计,数据库模式 SQL 语句生成。能够使用数据库设计工具进行数据库设计。

实验重难点

实验重点:概念结构设计、逻辑结构设计。

实验难点:逻辑结构设计。逻辑结构设计虽然可以按照一定的规则从概念结构转换而来,但是由于概念结构通常比较抽象,较少考虑更多细节,因此转换而成的逻辑结构还需要进一步调整与优化。逻辑结构承接概念结构和物理结构,处于核心地位,因此是数据库设计的重点和难点。

实验环境

DBMS:8.0.33 MySQL Community Server - GPL

可视化:Navicat Premium 16.1.6

命令行:Navicat自带命令列

Powerdesigner

实验过程

(0)数据库需求描述

设计一个图书馆管理系统,有注册读者,访客,管理员三种身份,需要管理图书的信息以及它的出版与存放地点信息。一个注册读者能借阅多本图书,一本图书(在不同的时间)能被不同读者借阅。一个访客能查询多本图书,一本图书能被多个访客查询。一个管理员管理图书,访客,注册读者(该图书由该管理员经手,该访客或注册读者由该管理员引导)。一本图书只能放在一个图书馆里,一本图书只能由一个出版社所出版。

对于借阅,记录借阅发生的时间,应该归还的时间,是否可以续借,借阅的终端地址。对于查询,记录查询发生的时间,以及查询发生的终端地址。

(1)数据库概念结构设计

E-R图

从需求描述中抽象出用于描述关系的E-R图如下。

在这里插入图片描述

实体

从需求描述中识别出以下6个实体,并分别为它们赋予属性。

图书馆library:
  • 图书馆编号:library_id
  • 图书馆名:library_name
  • 图书馆联系电话:library_tel
  • 图书馆地址:library_address
图书book:
  • 图书编号:book_id
  • 图书名称:book_name
  • 图书作者:book_writer
  • 图书编号:book_pressid
  • 图书出版日期:book_pressdate
  • 图书ISBN:book_isbn
  • 图书价格:book_price
  • 图书副本数量:book_copynum
出版社press:
  • 出版社编号:press_id
  • 出版社名:press_name
  • 出版社联系电话:press_tel
  • 出版社地址:press_address
注册读者reader:
  • 读者编号:reader_id
  • 读者姓名:reader_name
  • 读者性别:reader_sex
  • 读者电话号码:reader_tel
  • 读者邮箱地址:reader_email
  • 读者证件类型:reader_doc
  • 读者证件号码:reader_docid
  • 读者注册日期:reader_registerdate
  • 读者备注:reader_others
访客visitor:
  • 访客编号:visitor_id
  • 访客注册日期:visitor_registerdate
管理员admin:
  • 管理员编号:admin_id
  • 管理员姓名:admin_name
  • 管理员性别:admin_sex
  • 管理员电话号码:admin_tel
  • 管理员邮箱地址:admin_email
  • 管理员入职时间:admin_registerdate
  • 管理员职位:admin_pos
关系

关系在逻辑结构设计时补入完善的ER图中,这里先列出来。

借阅borrow
  • 借阅日期:borrow_date
  • 应归还日期:borrow_expect_returndate
  • 是否可续借:borrow_ifrenew
  • 是否归还:borrow_ifreturn
  • 最终归还日期:borrow_returndate
  • 借阅时间:borrow_time
  • 借阅终端地址:borrow_terminal(3位)
查询query
  • 查询时间:query_time
  • 查询终端地址:query_terminal
【初步使用PowerDesigner】

使用PowerDesigner可以很方便的绘制ER图,下面简单叙述该软件的初步操作。

①新建一个“概念模型”文件

在这里插入图片描述

②使用工具框绘制实体并连接关系

【注意】对于相似的实体,千万不要偷懒用ctrl+cv的方法,这个复制过去的不是一个新的副本,它更像是一个链接,用人话说就是,你修改了复制本或者原本,这两个都会跟着一起变化,很烦(多花了好多时间)。一定要自己新建出一个实体去写。

在这里插入图片描述

③编辑实体属性

双击实体,可以编辑实体属性,第一个Name是显示的中文,第二个Code是代码中呈现的。
在这里插入图片描述

点击Attributes设置实体的属性以及一些特征

在这里插入图片描述

词条具体含义如下:

  • Name:实体名字一般为中文(这是显示在图上给人看的)
  • Code:实体代号,一般用英文(这是写在代码里的,一定要用英文,不然无法生成代码)
  • Data Type:实体的数据类型
  • Length:实体的数据长度
  • Domain:域,表示属性取值范围如可以创建10个字符的地址域
  • M:Mandatory强制属性,表示该属性必填。不能为空(相当于NOT NULL)
  • P:Primary Identifer是否是主标识符,表示实体唯一标识符(相当于 PRIMARY KEY UNIQUE)
  • D:Displayed显示出来,默认全部勾选(这个要选上,否则就隐藏了)
④编辑关系的特征

同样地,双击关系,也可编辑相应特征。
在这里插入图片描述

这里可以调节映射关系,是1:1还是1:n还是n:m。

⑤检查模型

实际上可有可无,如果能正常生成,一般是没有问题的。

如果出现这样的错误

在这里插入图片描述

解决办法是把这两个勾去掉,不检查这两项即可。

在这里插入图片描述

【操作】

使用PowerDesigner绘制数据库概念模型图如下

在这里插入图片描述

(2)数据库逻辑结构设计

根据上述E-R图以及实体属性使用PowerDesigner设计数据库逻辑结构。

E-R图向关系模型的转换规则

  • 一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并。
  • 一个1:n联系可以转换为一个独立的关系模式,也可以与n端对应的关系模式合并。
  • 一个m:n联系只能转换为一个关系模式三个或三个以上实体间的一个多元联系转换为一个关系模式。
  • 具有相同码的关系模式可合并

(事实上,powerdesigner就是按照这个来的,最终它会合并所有1:1和1:n的关系,并为所有m:n的关系生成一个新的关系表)

【操作】

使用PowerDesigner创建数据库逻辑模型:Tool>Generate Logical Data Model即可生成数据库逻辑模型,直接点击生成即可,不需要做其它修改。生成如下:

在这里插入图片描述

这是它为我们生成的,我们可以看到多出来两个深色的部分,这就是为我们生成的两个新的关系表(这基本上只有在n:m的时候才会生成)。但实际上这还是不符合我们的预期的,比如对于借阅,我肯定要知道借阅发生的时间,应该归还的时间,以及是否可以续借等等这些额外的附加信息,对于查询,我可能想知道查询发生的时间,以及查询发生的终端地址等等,这些就需要我们手动对深色部分的模型作出更改。

对这两个关系表进行更改后,得到模型如下:

在这里插入图片描述

(3)数据库物理结构设计

数据库物理结构首先根据逻辑结构自动转换生成,然后根据应用需求设计数据库的索引结构、存储结构。

选择索引存取方法,数据库会自动为每个关系的主码建立索引。对于该系统,不需要建立其他索引。

【操作】

使用PowerDesigner创建数据库逻辑模型:Tool>Generate Physical Data Model即可生成数据库逻辑模型,这里要注意修改这个数据库为我们自己用的数据库(话说这个MySQL5.0是不是有点老了)。

在这里插入图片描述

结果如下:

在这里插入图片描述

(4)SQL语句生成

这一步可以自动生成SQL代码。

【操作】

使用PowerDesigner创建数据库逻辑模型:Database>GenerateDatabase,即可生成。这里可以设置文件的保存路径和文件名。

在这里插入图片描述

代码

最后生成的代码如下。

/*==============================================================*/
/* DBMS name:      MySQL 5.0                                    */
/* Created on:     2023/12/12 21:41:42                          */
/*==============================================================*/


drop table if exists admin;

drop table if exists book;

drop table if exists book_reader;

drop table if exists book_visitor;

drop table if exists library;

drop table if exists press;

drop table if exists reader;

drop table if exists visitor;

/*==============================================================*/
/* Table: admin                                                 */
/*==============================================================*/
create table admin
(
   admin_id             char(12) not null,
   admin_name           varchar(30) not null,
   admin_sex            char(2) not null,
   admin_tel            varchar(11) not null,
   admin_email          varchar(50) not null,
   admin_registerdate   date not null,
   admin_pos            varchar(30) not null,
   primary key (admin_id)
);

/*==============================================================*/
/* Table: book                                                  */
/*==============================================================*/
create table book
(
   book_id              char(50) not null,
   press_id             char(5),
   admin_id             char(12),
   library_id           char(5),
   book_name            varchar(50) not null,
   book_writer          varchar(30) not null,
   book_pressid         char(5) not null,
   book_pressdate       date not null,
   book_isbn            char(17) not null,
   book_price           float not null,
   book_copynum         int not null,
   primary key (book_id)
);

/*==============================================================*/
/* Table: book_reader                                           */
/*==============================================================*/
create table book_reader
(
   book_id              char(50) not null,
   reader_id            char(12) not null,
   borrow_date          date not null,
   borrow_expect_returndate date not null,
   borrow_ifrenew       char(1) not null,
   borrow_ifreturn      char(1) not null,
   borrow_returndate    date,
   borrow_time          time not null,
   borrow_terminal      char(3) not null,
   primary key (book_id, reader_id)
);

/*==============================================================*/
/* Table: book_visitor                                          */
/*==============================================================*/
create table book_visitor
(
   vistor_id            char(12) not null,
   book_id              char(50) not null,
   query_time           time not null,
   query_terminal       char(3) not null,
   primary key (vistor_id, book_id)
);

/*==============================================================*/
/* Table: library                                               */
/*==============================================================*/
create table library
(
   library_id           char(5) not null,
   library_name         varchar(30) not null,
   library_tel          char(8) not null,
   library_address      varchar(50) not null,
   primary key (library_id)
);

/*==============================================================*/
/* Table: press                                                 */
/*==============================================================*/
create table press
(
   press_id             char(5) not null,
   press_name           varchar(30) not null,
   press_tel            char(8) not null,
   press_address        varchar(50) not null,
   primary key (press_id)
);

/*==============================================================*/
/* Table: reader                                                */
/*==============================================================*/
create table reader
(
   reader_id            char(12) not null,
   admin_id             char(12),
   reader_name          varchar(30) not null,
   reader_sex           char(2) not null,
   reader_tel           char(11) not null,
   reader_email         varchar(50) not null,
   reader_doc           varchar(30) not null,
   reader_docid         varchar(50) not null,
   reader_registerdate  date not null,
   reader_others        varchar(256),
   primary key (reader_id)
);

/*==============================================================*/
/* Table: visitor                                               */
/*==============================================================*/
create table visitor
(
   vistor_id            char(12) not null,
   admin_id             char(12),
   vistor_registerdate  date not null,
   primary key (vistor_id)
);

alter table book add constraint FK_admin_book foreign key (admin_id)
      references admin (admin_id) on delete restrict on update restrict;

alter table book add constraint FK_book_library foreign key (library_id)
      references library (library_id) on delete restrict on update restrict;

alter table book add constraint FK_book_press foreign key (press_id)
      references press (press_id) on delete restrict on update restrict;

alter table book_reader add constraint FK_book_reader foreign key (book_id)
      references book (book_id) on delete restrict on update restrict;

alter table book_reader add constraint FK_book_reader2 foreign key (reader_id)
      references reader (reader_id) on delete restrict on update restrict;

alter table book_visitor add constraint FK_book_visitor foreign key (vistor_id)
      references visitor (vistor_id) on delete restrict on update restrict;

alter table book_visitor add constraint FK_book_visitor2 foreign key (book_id)
      references book (book_id) on delete restrict on update restrict;

alter table reader add constraint FK_admin_reader foreign key (admin_id)
      references admin (admin_id) on delete restrict on update restrict;

alter table visitor add constraint FK_admin_visitor foreign key (admin_id)
      references admin (admin_id) on delete restrict on update restrict;


验证

使用Navicat访问该sql。

在Navicat左边栏连接本地数据库,新建一个library数据库

在这里插入图片描述

在左边栏右击library>运行SQL文件…

在这里插入图片描述

设置在遇到“错误”继续运行,可能有错误,这是正常现象,因为我们设置了很多非空,而实际上我们还没有导入数据。

成功运行之后可以见到界面如下,我们成功建立了一个数据库。

在这里插入图片描述

使用Navicat自带的数据生成功能生成数据,下面是生成书的作者名字的一个示例。这些每个属性值都是可以我们自己指定规则或者给予引导的,也可以用正则表达式或者枚举来限制生成的结果。

【注意】由于书本我们定义了外键,所以要先人为写好至少一条admin,press,library的信息,否则book没法生成,因为外键是NOT NULL且没法被填充。

在这里插入图片描述

根据对应的规则生成出来关于书的数据(部分)如下(这里就没有去考虑一些细节,只是做做一个范例)。

在这里插入图片描述

对于左边的这些表格都可以做数据生成。

在这里插入图片描述

然后就可以在这个基础上做数据查询更新等等操作了。

如果导入的是真实的数据,就可以做一个真正的图书馆数据库系统。

当然还要加上java或php写的前端,这就不是本次实验涉及的内容了,是大作业需要考虑的了。

参考文献

https://blog.csdn.net/weixin_63246738/article/details/128744120

https://www.imangodoc.com/pFUil7ts.html

https://blog.csdn.net/Aaron503/article/details/128280233

https://blog.csdn.net/qq_51684393/article/details/128413966

实验感悟

实验没有太大的难度,主要的时间花在思考我要做什么,以及探索PowerDesigner的使用上。有几点感悟如下。

需求分析太重要。不得不说一个明确的需求分析真的是太重要太重要了,如果知道想要做什么,有明确的需求的话,完成几个部分的设计真的不是很难的事情。但如果需求分析没有做好,后面真的就没办法开展。

PowerDesigner很好用。这个工具真的是太强大了,首先是很用户友好,对于一个纯新手,看看教程短时间可以上手。此外是逻辑很清晰,看看这张图,左边的栏从上往下依次就是“概念模型”,“逻辑模型”,“物理模型”,最后再生成SQL代码。工具清晰加上思路清晰,就能很快完成任务。

在这里插入图片描述

实验过程有意义。算是完整地走了一遍很简单的数据库雏形设计,挺有价值,为以后大作业奠定了一些基础。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/303314.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

电子电器架构网络演化 —— 车载以太网TSN

电子电器架构网络演化 —— 车载以太网TSN 我是穿拖鞋的汉子&#xff0c;魔都中坚持长期主义的汽车电子工程师。 老规矩&#xff0c;分享一段喜欢的文字&#xff0c;避免自己成为高知识低文化的工程师&#xff1a; 屏蔽力是信息过载时代一个人的特殊竞争力&#xff0c;任何消…

Weblogic安全漫谈(一)

前言 frohoff在2015年初发现commons-collections的反序列化利用链并发布了ysoserial工具[1]。9个月后&#xff0c;breenmachine对众多知名Java中间件的利用文章[2]使Java反序列化漏洞变得广为人知&#xff0c;Weblogic中首当其冲的就是大家多少都有点耳熟的T3协议反序列化。本…

家用洗地机哪款好用?洗地机品牌排行榜推荐

在如今的日常生活中&#xff0c;家用洗地机已经成为了家庭清洁中不可或缺的工具。然而&#xff0c;市面上各种不同品牌型号的洗地机让人眼花缭乱&#xff0c;让人难以选择。那么&#xff0c;家用洗地机现在买什么牌子质量好呢?为了解答这个问题&#xff0c;笔者选了几款品牌质…

Vue3+Vite打包跨平台(七牛、阿里OSS)上传部署前端项目

1、业务场景 阅读之前&#xff0c;想了解一下各位观众老爷们&#xff0c;你们公司的项目是怎么部署的&#xff1a; 1.本地打包手动上传服务器&#xff1b; 2.本地打包自动上传服务器&#xff1b; 3.代码仓库流水线自动构建&#xff1b; 4.其他…&#xff1b; 我们用的第3种部…

【Linux Shell】11. 输入/输出 重定向

文章目录 【 1. 重定向简介 】【 2. 输出重定向 】【 3. 输入重定向 】【 4. Here Document 】【 5. /dev/null 文件 】 【 1. 重定向简介 】 大多数 UNIX 系统命令从终端接受输入并将所产生的输出发送回​​到原来输入的终端。一个命令通常从标准输入的地方读取输入&#xff…

MySql8的那些不为人知的秘密揭晓

前言 MySQL 8.0 是MySQL数据库的一个重大版本更新&#xff0c;带来了许多改进和新功能。以下是MySQL 8.0的一些主要改进&#xff1a; 事务控制&#xff1a;引入了原子性、一致性、隔离性和持久性&#xff08;ACID&#xff09;的事务支持。该版本的MySQL引入了新的事务日志存储引…

Mysql大数据量下流式查询优化:Jdbc中的useFetchSize参数及其原理解析

前言 最近我朋友公司有个需求场景&#xff1a;查询千万级数据量并写入txt文件的程序优化需求。 朋友找到我对程序进行优化&#xff0c; 不然饭碗不保......&#x1f4a6; 下面就分享一下解决这个优化问题的过程和思路&#xff0c;并总结一下&#xff0c;在以后不要在踩同样的坑…

4.4 TILING FOR REDUCED MEMORY TRAFFIC

我们在CUDA中使用设备内存方面有一个内在的权衡&#xff1a;全局内存大但速度慢&#xff0c;而共享内存小但速度快。一个常见的策略是将数据划分为称为tile的子集&#xff0c;以便每个tile都适合共享内存。tile一词”借鉴了一个类比&#xff0c;即大墙&#xff08;即全局内存数…

基于协同过滤推荐的购物系统

介绍 本购物系统是一个基于协同过滤推荐算法的电商平台&#xff0c;使用 Python Django 框架、Django-simpleui 前端框架和 Vue、Element-Plus UI 组件库构建而成。该系统可根据关键词、分类等搜索筛选商品&#xff0c;并提供了个性化推荐功能&#xff0c;根据用户的历史订单、…

linux日志管理

一.inode与block 访问文件的流程&#xff1a; 根据文件夹的文件名和inode号&#xff0c;找到对应的inode表&#xff0c;再根据inode表的指针找到磁盘上的真实数据 tips&#xff1a;我磁盘空间还剩很多&#xff0c;但是无法建立文件&#xff1f; 因为inode号被分完了 解决方法&a…

交通银行网上支付接口调用测试实例

公司最近有一个网站商城项目要开始开发了&#xff0c;这几天老板和几个同事一起开着需求会议&#xff0c; 讨论了接下来的业务规划和需求策略&#xff0c;等技术需求一下来还要讨论技术需求&#xff0c; 确认后再慢慢的进入开发阶段&#xff0c;趁着闲暇时间新造的人想总结一…

C语言中常用的字符串函数(strlen、sizeof、sscanf、sprintf、strcpy)

C语言中常用的字符串函数 文章目录 C语言中常用的字符串函数1 strlen函数2 sizeof函数2.1 sizeof介绍2.2 sizeof用法 3 sscanf函数3.1 sscanf介绍3.2 sscanf用法3.3 sscanf高级用法 4 sprintf函数4.1 背景4.2 sprintf用法 5 strcpy函数5.1 strcpy介绍5.1 strcpy用法 1 strlen函…

算法第十四天-删除有序数组中的重复项

删除有序数组中的重复项 题目要求 解题思路 双指针 左指针确定不重复值&#xff0c;右指针遍历数组 代码 class Solution:def removeDuplicates(self, nums: List[int]) -> int:left0for right in range(1,len(nums)):if nums[left] ! nums[right]:left 1nums[left] nu…

【问题】SpringBoot项目中log4j与logback的Jar包冲突问题

这篇文章主要给大家介绍了解决SpringBoot项目中log4j与logback的Jar包冲突问题,文中有详细的解决方法和冲突的原因。 SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar:file:/C:/Users/lx/.m2/repository/org/slf4j/slf4j-log4j12/1.7.25/sl…

【工具】推荐一个好用的代码画图工具

PlantUML 官网地址&#xff1a;https://plantuml.com/zh/ 跳转 支持各种结构化数据画图支持代码调用jar包生成图片 提供在线画图能力 https://www.plantuml.com/plantuml/uml/SyfFKj2rKt3CoKnELR1Io4ZDoSa70000 有兴趣可以尝试下 over~~

20.Activity跳转时的参数传递

(1).如何传递数据 (2).如何接收数据 (3).如何回传数据

消息队列-RockMQ-批量收发实践

批量收发实战 发送消息是需要网络连接的如果我们单条发送吞吐量可能没有批量发送好。剖来那个发送可以减少网络IO开销&#xff0c;但是也不能一批次发送太多的数据&#xff0c;需要根据每条消息的大小和网络带宽来确定量的数目。 比如网络带宽为可以支持一次性发送8M的数据包&…

工业异常检测AnomalyGPT-Demo试跑

写在前面&#xff1a;如果你有大的cpu和gpu可以使用&#xff0c;直接根据官方的安装说明就可以&#xff0c;如果没有&#xff0c;可以点进来试着看一下我个人的安装经验。 一、试跑环境 NVIDIA4090显卡24g,cpu内存33G&#xff0c;交换空间8g,操作系统ubuntu22.04(试跑过程cpu…

OCP NVME SSD规范解读-5.命令超时限制

在"4.7 Command Timeout"章节中&#xff0c;详细定义了NVMe命令的超时要求和限制。 CTO-1&#xff1a;NVMe管理命令和TCG&#xff08;可信计算组&#xff09;命令从提交到完成不应超过10秒&#xff0c;且没有其他命令未完成&#xff08;QD1&#xff09;。CTO-1不适用…

九州金榜|家庭教育小技巧如何培养优秀孩子

信任和期望可以激发孩子的智商和能力&#xff0c;孩子是否出色&#xff0c;取决于家长们如何去“套路”去“培养”。 优秀的孩子不是逼出来的&#xff0c;而是被父母套路出来的&#xff0c;引导孩子找到自我价值感&#xff0c;才是家庭教育中最重要的一课&#xff01; 曾经看…