【MySql】实验十六 综合练习:图书管理系统数据库结构

文章目录

  • 创建图书管理系统数据库结构
    • 一、创建数据表
      • 1.1 book表
      • 1.2 reader表
      • 1.3 borrow表
    • 二、插入示例数据
      • 2.1 向book表插入数据
      • 2.2 向reader表插入数据
      • 2.3 向borrow表插入数据
    • 三、查询操作
      • 3.1 根据语义为借书表borrow的bno列和 rno列建立外键
      • 3.2 查询张小海编写的“数据库原理”的出版日期。
      • 3.3 查询“操作系统”的所有借书记录。
      • 3.4 查询图书表的所有记录,按出版社和出版日期排序。
      • 3.5 查询每个读者借书的次数。
      • 3.6 查询没有被任何人借过的图书的图书编号、图书名称、作者。
    • 四、视图和索引
      • 4.1 建立视图bookview
      • 4.2 在图书表 book 的出版日期列上建立索引
      • 4.2 继承book创建tbook表信息插入
      • 4.3 删除tbook表
    • 五、存储过程和触发器
      • 5.1 创建存储过程bookproc
      • 5.2 执行存储过程bookproc
      • 5.3 创建触发器newtrigger
    • 六、自定义函数
      • 6.1 创建自定义函数borrowcount
    • 七、数据库备份
      • 7.1 备份数据库


创建图书管理系统数据库结构

在本篇博客中,我们将一步步创建一个简单的图书管理系统数据库。我们将定义三个主要的数据表:book(图书信息)、reader(读者信息)和borrow(借书记录)。下面是每个表的详细结构。

一、创建数据表

1.1 book表

存储图书信息的表。

列名数据类型是否可为空主键
bnoachar(4)
bnamechar(20)
authorchar(10)
publishchar(20)
pubdatedatetime
-- 创建book表
CREATE TABLE book(bnoa char(4) NOT NULL PRIMARY KEY,  -- 图书编号,主键,不允许为空bname char(20) NOT NULL,             -- 图书名称,不允许为空author char(10) NOT NULL,            -- 作者,不允许为空publish char(20) NOT NULL,           -- 出版社,不允许为空pubdate datetime NOT NULL            -- 出版日期,不允许为空
);

1.2 reader表

存储读者信息的表。

列名数据类型是否可为空主键
rnochar(4)
rnamechar(10)
-- 创建reader表
CREATE TABLE reader(rno char(4) NOT NULL PRIMARY KEY,  -- 读者编号,主键,不允许为空rname char(10) NOT NULL             -- 读者姓名,不允许为空
);

1.3 borrow表

存储借书记录的表。

列名数据类型是否可为空主键
borrownoint
bnochar(4)
rnochar(4)
borrowdatedatetime
-- 创建borrow表
CREATE TABLE borrow(borrowno int PRIMARY KEY,           -- 借书记录编号,主键,不允许为空bno char(4),                        -- 图书编号,可以为空rno char(4),                        -- 读者编号,可以为空borrowdate datetime                 -- 借书日期,可以为空
);

二、插入示例数据

2.1 向book表插入数据

-- 向book表插入数据
INSERT into book(bnoa,bname,author,publish,pubdate)
VALUES 
(0001,"数据库原理","张小海","人民邮电出版社","2020-10-01"),
(0002,"软件工程","李莎莎","高等教育出版社","2020-08-09"),
(0003,"操作系统","钱东升","人民邮电出版社","2021-03-06"),
(0004,"数据结构","鲁明浩","清华大学出版社","2021-05-28"),
(0005,"编译原理","张悦","高等教育出版社","2021-10-30");

2.2 向reader表插入数据

-- 向reader表插入数据
insert into reader(rno,rname)
VALUES
("0001","全志忠"),
("0002","孙佳佳"),
("0003","司马精");

2.3 向borrow表插入数据

-- 向borrow表插入数据
insert into borrow
VALUES
("1","0001","0001","2021-11-15"),
("2","0002","0001","2021-11-20"),
("3","0002","0002","2021-11-30"),
("4","0003","0002","2021-12-05"),
("5","0003","0001","2021-12-12"),
("6","0004","0001","2021-12-21");

三、查询操作

3.1 根据语义为借书表borrow的bno列和 rno列建立外键

alter table borrow add FOREIGN KEY (bno)  REFERENCES book(bnoa); 
alter table borrow add FOREIGN KEY (rno)  REFERENCES reader(rno);

3.2 查询张小海编写的“数据库原理”的出版日期。

-- 查询张小海编写的“数据库原理”的出版日期
select pubdate
FROM book
where author="张小海" AND bname="数据库原理";

在这里插入图片描述
在这里插入图片描述

3.3 查询“操作系统”的所有借书记录。

-- 查询“操作系统”的所有借书记录
select *
from book b,borrow bo,reader r
where b.bnoa=bo.bno and bo.rno=r.rno
and b.bname="操作系统";

在这里插入图片描述

3.4 查询图书表的所有记录,按出版社和出版日期排序。

查询图书表的所有记录,查询结果按出版社和出版日期排序,出版社的排序条件为降序,出版日期的排序条件为升序。

-- 查询图书表的所有记录,按出版社和出版日期排序
SELECT *
FROM book
ORDER BY publish DESC, pubdate ASC;

在这里插入图片描述

3.5 查询每个读者借书的次数。

查询每个读者借书的次数,查询结果由“读者编号”和“借书次数”两列组成。

-- 查询每个读者借书的次数
select r.rno as "读者编号",COUNT(bw.borrowno) as "借书次数"
FROM reader r
left join borrow bw on r.rno=bw.rno
GROUP BY r.rno;

在这里插入图片描述

3.6 查询没有被任何人借过的图书的图书编号、图书名称、作者。

-- 查询没有被任何人借过的图书的图书编号、图书名称、作者
select b.bnoa,b.bname,b.author
from book b
LEFT JOIN borrow bw on b.bnoa =bw.bno
where bw.bno is NULL;

在这里插入图片描述

四、视图和索引

4.1 建立视图bookview

建立新的名为bookview的视图,该视图检索“人民邮电出版社”出版的所有图书的图书名称、作者和出版日期。

-- 建立视图bookview
CREATE VIEW bookview as
select bname,author,pubdate
FROM book
where publish="人民邮电出版社";

在这里插入图片描述

4.2 在图书表 book 的出版日期列上建立索引

在图书表 book 的出版日期列上建立名为pubdatcindex的普通索引,要求该索引采取降序排列。

-- 在图书表 book 的出版日期列上建立索引
CREATE INDEX pubdatcindex ON book (pubdate DESC);

4.2 继承book创建tbook表信息插入

建立新的名为tbook 的表,该表的结构与 book表完全一样,利用一个INSERT语句将“人民邮电出版社”出版的所有图书信息插人入book表中。

-- 建立tbook表格 继承 book
CREATE table tbook like book;

在这里插入图片描述

  • 将“人民邮电出版社”出版的所有图书信息插人tbook表中。
INSERT INTO tbook
SELECT *
FROM book
WHERE publish = '人民邮电出版社';

在这里插入图片描述
在这里插入图片描述

4.3 删除tbook表

12)删除第(11)步建立的表tbook。DROP TABLE tbook;

五、存储过程和触发器

5.1 创建存储过程bookproc

创建拥有一个参数的bookproc()存储过程,用来查询图书表中由该参数指定作者的所有图书的图书名称、出版社和出版日期,然后执行该存储过程,并将输入参数赋值“张小海”。

-- 创建存储过程bookproc
DELIMITER //
CREATE PROCEDURE bookproc(IN authorName char(10))
BEGINSELECT bname, publish, pubdateFROM bookWHERE author = authorName;
END //
DELIMITER ;

在这里插入图片描述

5.2 执行存储过程bookproc

-- 执行存储过程bookproc
CALL bookproc("张小海");

在这里插入图片描述

5.3 创建触发器newtrigger

建立名为newtrigger的触发器,触发器规定,当删除读者表中的一条记录时将借书表中相应读者的借书记录一并删除,然后删除读者表中的一条记录以触发触发器。

-- 创建触发器newtrigger
DELIMITER //
CREATE TRIGGER newtrigger AFTER DELETE ON reader
FOR EACH ROW
BEGINDELETE FROM borrow WHERE rno = OLD.rno;
END //
DELIMITER ;

在这里插入图片描述

六、自定义函数

6.1 创建自定义函数borrowcount

建立borrowcount(自定义函数,该函数用于输人读者的编号以返回该读者的借书次数,如果编号不存在则返回-1。

-- 创建自定义函数borrowcount
DELIMITER //
CREATE FUNCTION borrowcount(rno char(4))
RETURNS int
BEGINDECLARE borrowCount int;SELECT COUNT(*) INTO borrowCount FROM borrow WHERE rno = rno;IF borrowCount IS NULL THENSET borrowCount = -1;END IF;RETURN borrowCount;
END //
DELIMITER ;

在这里插入图片描述

七、数据库备份

7.1 备份数据库

-- 备份数据库
mysqldump -u username -p Book > D:/bookbackup.sql

请注意,以上备份命令需要在MySQL命令行中执行,并且您需要将username替换为您的MySQL用户名。此命令会将整个Book数据库备份到D盘根目录下的bookbackup.sql文件中。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AutoDL部署视觉大模型llama3.2-vision,从视频中寻找特定目标

注: windows11系统。示例为此项目:https://github.com/win4r/VideoFinder-Llama3.2-vision-Ollama 在当今的人工智能领域,深度学习模型的计算需求日益增长,特别是在处理复杂的视觉任务时,强大的算力往往是实现高效应用…

【机器学习】聚类算法原理详解

聚类算法 性能度量: 外部指标 jaccard系数(简称JC)FM指数(简称FMI)Rand指数(简称RI) 内部指标 DB指数(简称DBI)Dunn指数(简称DI) 距离计算&am…

前端性能优化深入解析:提升用户体验的几个关键点

文章目录 前言一、代码分割与动态导入二、图片和脚本的懒加载三、缓存策略四、如何根据项目特点选择合适的前端性能优化策略?结语 前言 在当今的互联网环境中,网页加载速度直接影响到用户的满意度和留存率。因此,前端性能优化对于提高用户体…

系统架构设计师论文

资源库:https://blog.csdn.net/weixin_43905586/article/details/118719986 2019年 2019年下半年试题二:论软件系统架构评估及其应用 2012年 2012年下半年试题一:论基于架构的软件设计方法及应用

用 Android Studio 从零开发一个多功能计算器应用

简介 计算器是每个学习 Android 开发者必经的经典项目之一。本篇文章将带你创建一个功能更强大的计算器应用,支持基本的加减乘除运算、带小数点的输入以及更多操作符功能。通过这个项目,你将全面掌握 Android 的布局设计、事件处理和逻辑实现技巧。 一、…

【代码随想录day33】【C++复健】62.不同路径;63. 不同路径 II;343. 整数拆分;96.不同的二叉搜索树

感觉dp的题真的很适合背,当然不是死记硬背,而是当做一种模板题,出来一道新的题就往模板题上面去靠,如果套对模板的话剩下的事情其实就简单了。所以只要看一遍解法知道大致思路其实就够了,毕竟大部分dp的代码也不算难写…

SHELL笔记(条件测试)

基本概念: 条件测试用于在 Shell 脚本中对各种条件进行判断,根据判断结果来决定是否执行特定的命令或代码块。条件测试可以用于比较数值、字符串,检查文件或目录的属性,以及判断命令的执行结果等。 格式: 格式1&…

JDK、MAVEN与IDEA的安装与配置

1.认识JDK、MAVEN与IDEA JDK 提供了编译和运行Java程序的基本环境。Maven 帮助管理项目的构建和依赖。IDEA 提供了一个强大的开发环境,使得编写、调试和运行Java程序更加高效。 2. 安装与环境配置 2.1 官网地址 选择你需要的版本下载: MAVEN下载传送…

微信小程序-prettier 格式化

一.安装prettier插件 二.配置开发者工具的设置 配置如下代码在setting.json里: "editor.formatOnSave": true,"editor.defaultFormatter": "esbenp.prettier-vscode","prettier.documentSelectors": ["**/*.wxml"…

【Mac】未能完成该操作 Unable to locate a Java Runtime

重生之我做完产品经理之后回来学习Data Mining Mac打开weka.jar报错"未能完成该操作 Unable to locate a Java Runtime" 1. 打开终端执行 java -version 指令,原来是没安装 JDK 环境 yyzccnn-mac ~ % java -version The operation couldn’t be comple…

【ArcGIS微课1000例】0127:计算城市之间的距离

本文讲述,在ArcGIS中,计算城市(以地级城市为例)之间的距离,效果如下图所示: 一、数据准备 加载配套实验数据包中的地级市和行政区划矢量数据(订阅专栏后,从私信查收数据),如下图所示: 二、计算距离 1. 计算邻近表 ArcGIS提供了计算点和另外点之间距离的工具:分析…

【WPF】Prism学习(五)

Prism Commands 1.错误处理(Error Handling) Prism 9 为所有的命令(包含AsyncDelegateCommand)提供了更好的错误处理。 避免用try/catch包装每一个方法根据不同遇到的异常类型来提供特定的逻辑处理可以在多个命令之间共享错误处…

【element-tiptap】Tiptap编辑器核心概念----结构篇

core-concepts 前言:这篇文章来介绍一下 Tiptap 编辑器的一些核心概念 (一)结构 1、 Schemas 定义文档组成方式。一个文档就是标题、段落以及其他的节点组成的一棵树。 每一个 ProseMirror 的文档都有一个与之相关联的 schema,…

2024.6使用 UMLS 集成的基于 CNN 的文本索引增强医学图像检索

Enhancing Medical Image Retrieval with UMLS-Integrated CNN-Based Text Indexing 问题 医疗图像检索中,图像与相关文本的一致性问题,如患者有病症但影像可能无明显异常,影响图像检索系统准确性。传统的基于文本的医学图像检索&#xff0…

PGMP-练DAY26

1. Which of the following items are key elements of the program charter?以下哪些项目是项目集章程的关键要素? A.Scope, assumptions,constraints,goals and objectives, timing, key stakeholders.范围、假设、约束、目标和目的、时间安排、主要利益相关者 …

Spark_写ORALCE:ORA-01426 numeric overflow 问题解决

问题 是这样的,20241118,我spark程序写Oracle时候,关联完HBase数据后,在写入ORACLE中,遇到了这个bug, 数据入到一半,每次都报错ORA-01426 numeric overflow,具体呢,也不告…

初识Linux · 信号处理 · 续

目录 前言: 可重入函数 重谈进程等待和优化 前言: 在前文,我们已经介绍了信号产生,信号保存,信号处理的主题内容,本文作为信号处理的续篇,主要是介绍一些不那么重要的内容,第一个…

流量模型 -20241118

流量模型 个体的注意力注意力提升销量,转化为直接收益,同时提升品牌价值购物平台的出现使注意力变现变得简单,开拓了注意力的的使用方式,使其分散使用转变为集中使用各个视频,直播平台集中注意力,使得流量…

微信小程序 最新获取用户头像以及用户名

一.在小程序改版为了安全起见 使用用户填写来获取头像以及用户名 二.代码实现 <view class"login_box"><!-- 头像 --><view class"avator_box"><button wx:if"{{ !userInfo.avatarUrl }}" class"avatorbtn" op…

WPF MVVM框架

一、MVVM简介 MVC Model View Control MVP MVVM即Model-View-ViewModel&#xff0c;MVVM模式与MVP&#xff08;Model-View-Presenter&#xff09;模式相似&#xff0c;主要目的是分离视图&#xff08;View&#xff09;和模型&#xff08;Model&#xff09;&#xff0c;具有低…