MySQL数据库实验三

本文承接前面的俩次实验基础上完成,不过实现的都是基础操作的练习

目录

目录

前言

实验目的

实验要求

实验内容及步骤

updata操作

delete操作 

alter操作

添加列

删除列

修改列的数据类型

要求实现

实验结果

代码结果

注意事项

思考题

总结


前言

本文是MySQL数据库的简单操作的练习实验,掌握基本的sql练习。了解数据库的维护操作,包含数据的插入、检索、修改,掌握MySQL 中用户、角色及操作权限的管理方法,学会创建和使用规则、缺省和触发器。


实验目的

要求学生熟练使用和掌握数据库的维护操作,包含数据的插入、检索、修改,掌握MySQL 中用户、角色及操作权限的管理方法,学会创建和使用规则、缺省和触发器。

实验要求

1. 将B5的单价改为6.00元

2. 删去图书B2及的单价改为6.00元

3. 修改江苏新华书店的图书的数量为50

4. 为图书发行LBS表的QTY字段设计CHECK约束:  0<QTY<100

5. 将(B6,人工智能库论,4.5)加入图书B

6. 实现对LBS表的操作权限管理的使用。

实验内容及步骤

updata操作

UPDATE table_name  
SET column1 = value1, column2 = value2, ...  
WHERE condition;

delete操作 

DELETE FROM table_name  
WHERE condition;

alter操作

添加列

ALTER TABLE students  
ADD email VARCHAR(255);
-- 例子
ALTER TABLE students  
ADD email VARCHAR(255);

删除列

ALTER TABLE table_name  
DROP COLUMN column_name;
-- 例子
ALTER TABLE students  
DROP COLUMN email;

修改列的数据类型

ALTER TABLE table_name  
MODIFY COLUMN column_name new_datatype;
-- 例子
ALTER TABLE students 
MODIFY COLUMN age SMALLINT;

这里只枚举了alter几个作用,alter实际上还有很多功能可以使用。 

要求实现

1. 将B5的单价改为6.00元
只要直接在B表中使用UPDATE修改对应B5的价格即可

-- 将B5的单价改为6.00元
select * from b;
UPDATE B SET PRICE = 6.00 WHERE BNO = 'B5';

2. 删去图书B2及的单价改为6.00元

首先,删除图书B2的发行记录(因为可能存在外键约束,需要先删除外键表中的数据),然后,删除图书B2的记录.

-- 删去图书B2及相应的发行记录
DELETE FROM LBS WHERE BNO = 'B2';
select *from lbs;
DELETE FROM B WHERE BNO = 'B2';
select *from b;

3. 修改江苏新华书店的图书的数量为50

由于图书数量只在LBS表中,而江苏新华书店只在S表中,我们在使用updata更改LBS中数量数据前,要用sno来使俩个表产生链接,找到对应需要修改的数据

-- 修改江苏新华书店的图书的数量为50
select * from S;
select * from LBS;
SELECT SNO FROM S WHERE SNAME = '江苏新华书店';
UPDATE LBS SET QTY = 50 WHERE SNO = (SELECT SNO FROM S WHERE SNAME = '江苏新华书店');

4. 为图书发行LBS表的QTY字段设计CHECK约束:  0<QTY<100
用alter可以调增LBS表,使用ADD CONSTRAINT添加约束
同时可以使用下述的代码查询是有在约束名中有新增添的约束

-- 为图书发行LBS表的QTY字段设计CHECK约束:  0<QTY<100
select * from LBS;
ALTER TABLE LBS ADD CONSTRAINT CHK_QTY CHECK (QTY > 0 AND QTY < 100);
-- 查找约束名
SELECT constraint_name
FROM information_schema.table_constraints
WHERE table_name = 'LBS' AND constraint_type = 'CHECK';

5. 将(B6,人工智能库论,4.5)加入图书B
主要使用insert进行数据的插入

-- 将(B6,人工智能库论,4.5)加入图书B
select * from b;
INSERT INTO B (BNO, BNAME, PRICE) VALUES ('B6', '人工智能库论', 4.50);

6. 实现对LBS表的操作权限管理的使用。

首先要创建用户,然后提供不同操作的权限,同时提供了查询用户权限和删除的操作

-- 实现对LBS表的操作权限管理的使用。
CREATE USER 'lbs_user'@'localhost' IDENTIFIED BY '123456';
-- 允许用户查询LBS表:
GRANT SELECT ON bookdistribution.LBS TO 'lbs_user'@'localhost';
-- 允许用户插入、更新和删除LBS表中的数据:
GRANT INSERT, UPDATE, DELETE ON bookdistribution.LBS TO 'lbs_user'@'localhost';
-- 允许用户执行所有操作(包括创建和删除表等):并未执行
GRANT ALL PRIVILEGES ON bookdistribution.LBS TO 'lbs_user'@'localhost';
-- 查询用户
SHOW GRANTS FOR 'lbs_user'@'localhost';
-- 删除用户
DROP USER 'lbs_user'@'localhost';

实验结果

代码结果

1. 将B5的单价改为6.00元

2. 删去图书B2及的单价改为6.00元

3. 修改江苏新华书店的图书的数量为50

4. 为图书发行LBS表的QTY字段设计CHECK约束:  0<QTY<100

5. 将(B6,人工智能库论,4.5)加入图书B

6. 实现对LBS表的操作权限管理的使用。

注意事项

1、数据更改时要注意外码约束:在更改数据时,如果涉及到外键约束的表,需要先确保外键表中没有引用到这些数据,或者适当地更新外键表中的数据以维持数据的一致性和完整性。

2、数据删除时要注意外码约束:在删除数据时,如果涉及到外键约束的表,需要先删除外键表中的数据或者解除外键约束,然后再删除主表中的数据。

3、用户、角色和权限的职能,以及它们之间的关系:用户是访问数据库的主体,角色是一组权限的集合,用户可以被赋予一个或多个角色,从而继承角色的权限。这样,通过角色管理权限可以简化权限管理过程。

思考题

1、为什么不能随意删除被参考表中的主码:因为被参考表(通常称为父表或主表)的主码在子表(通常称为外键表)中被用作外键,用于维护两个表之间的关联关系。如果随意删除父表的主码数据,可能会导致子表中的外键数据失效或成为悬空引用,破坏数据的完整性和一致性。

2、数据库中一般不允许更改主码数据。如果需要更改主码数据时,怎样处理:如果确实需要更改主码数据,通常需要先删除原有的数据记录,然后插入新的数据记录,同时更新所有外键表中引用该主码的数据。但在实际操作中,这通常不是一个好的做法,因为可能会导致数据丢失或不一致。更好的做法是在设计数据库时尽量避免需要更改主码的情况。

3、两种SQL Server的安全认证模式及特点:SQL Server支持两种安全认证模式:Windows身份验证模式和混合身份验证模式。Windows身份验证模式使用Windows账户和密码进行身份验证,简化了管理并提供了更强的安全性。混合身份验证模式允许使用Windows账户和SQL Server账户进行身份验证,提供了更大的灵活性。

4、什么是触发器?主要功能是什么:触发器(Trigger)是一种特殊的存储过程,它会在指定的表上进行INSERT、UPDATE或DELETE操作时自动执行。触发器的主要功能包括数据完整性检查、数据审计、级联更新和删除等。通过触发器,可以在数据发生更改时自动执行一系列操作,以确保数据的完整性和一致性。


总结

通过对于MySQL数据实验的要求实现,额外了解了一些原本并未学到的操作。
了解了数据库的维护操作,包含数据的插入、检索、修改,掌握MySQL 中用户、角色及操作权限的管理方法,学会创建和使用规则、缺省和触发器。

推荐学习博客 https://xxetb.xetslk.com/s/4GgGz6

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

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

相关文章

c++11 lambda 捕获,匿名,返回类型后置

lambda就是即写即用的匿名函数&#xff0c;可以用于解决匹配函数参数的问题 int main(int argc,char *argv[]) {vector<int> v{1,2,3,4,5,6,7,8};for_each(v.begin(),v.end(),[](int a){cout<<a;});return 0; } for_each是固定函数&#xff0c;我们需要他但是又没…

MySQL中JOIN连接的实现算法

目录 嵌套循环算法&#xff08;NLJ&#xff09; 简单嵌套循环&#xff08;SNLJ&#xff09; 索引嵌套循环&#xff08;INLJ&#xff09; 块嵌套循环&#xff08;BNLJ&#xff09; 三种算法比较 哈希连接算法&#xff08;Hash Join&#xff09; 注意事项&#xff1a; 工…

分享5个免费AI一键生成毕业论文的网站

一、引言 对于忙碌的学生来说&#xff0c;毕业论文通常是一项艰巨的任务。幸运的是&#xff0c;随着人工智能技术的发展&#xff0c;现在有一些工具可以帮助学生轻松完成论文。本文将介绍五个免费的AI工具&#xff0c;它们能够一键帮助你生成毕业论文&#xff0c;让你的学术生…

Linux流程控制

if语句 基本格式 if condition thencommand1 fi 写成一行 if [ $(ps -ef | grep -c "ssh") -gt 1 ]; then echo "true"; fi if-else语句 格式 if condition thencommand1 command2...commandN elsecommand fi if else- if else if condition1 th…

wordpress忘记后台密码,在数据库中修改回来,然后再修改回去。

源地址&#xff1a;https://www.ctvol.com/seoomethods/1421332.html 我们在做wordpess运维的时候&#xff0c;都会遇到很尴尬的时候&#xff0c;有时候在错误运维中&#xff0c;不知道删除了什么东西&#xff0c;造成wordpress后台不能登录&#xff0c;后台页面也直接失效&am…

Google Chrome浏览器便携增强版 v124.0.6367.61

01 软件介绍 Google Chrome v124.0.6367.61&#xff0c;这一版本经过精心设计&#xff0c;集成了一系列的功能增强和关键补丁&#xff0c;旨在提升用户体验。其中&#xff0c;Chrome引入了便携性数据保存选项&#xff0c;优化了标签页及标签栏的操作机制。此外&#xff0c;它还…

互联网黑话知所多少?

互联网黑话是互联网公司形成的一套带有浓厚互联网行业特色的“非正式语言”。这些黑话通常起源于社交媒体、网络论坛、技术博客以及职场交流中&#xff0c;它们可能是缩写词、行业术语、梗或者其它专业领域的词汇。来盘一盘你常听、常用的互联网黑话都有哪些吧&#xff01;

分布式与一致性协议之ZAB协议(七)

ZAB协议 ZAB协议:如何处理读写请求 你应该有这样的体会&#xff0c;如果你想了解一个网络服务&#xff0c;执行的第一个功能肯定是写操作&#xff0c;然后才会执行读操作。比如&#xff0c;你要了解ZooKeeper&#xff0c;那么肯定会在zkClient.sh命令行中执行写操作(比如crea…

SAP PP学习笔记09 - 作业区(工作中心Work Center)Customize2(管理码,班次顺序,计算式),标准Text,作业区阶层

上文讲了作业区&#xff08;工作中心&#xff09;的概念及其中重要字段&#xff0c;以及作业区的部分Customize。 SAP PP学习笔记08 - 作业区&#xff08;工作中心Work Center&#xff09;&#xff0c;作业区Customize-CSDN博客 本文继续讲 作业区的Customize。 Spro > 生…

杨氏矩阵查找算法

有一个数字矩阵&#xff0c;矩阵的每行从左到右是递增的&#xff0c;矩阵从上到下是递增的&#xff0c;请编写程序在这样的矩阵中查找某个数字是否存在。 要求&#xff1a;时间复杂度小于O(N); 1.首先更直观地了解一下杨氏矩阵&#xff1a; 123456789 这就是一个简单的杨氏矩…

【Java】初识网络编程

文章目录 前言✍一、互联网的发展1.独立模式2.网络的出现局域网LAN广域网WAN ✍二、网络编程概述✍三、网络编程中的术语介绍IP地址端口号协议OSI七层模型TCP\IP四层模型 ✍四、协议的层级之间是如何配合工作的 前言 在本文中&#xff0c;会对网络编程的一些术语进行解释&#…

MySQL变量的声明与使用

set userName 刘德华; SELECT userName : 刘青云; SELECT userName as 读取到的userName变量值; set x5,y7; SELECT x y as 57的结果; set dx0.55,dy2; SELECT dx dy; set result(select dx dy) SELECT result; set cityName1Kabul; SET cityName2Qandahar; SET cityName3…

【Qt 开发基础体系】字符串类应用和常用的数据类型

文章目录 1. Qt 字符串类应用1.1 操作字符串1.2 QString::append()函数1.3 QString::sprintf()函数1.4 QString::arg()函数 2. 查询字符串2.1 函数 QString::startsWith()2.2 函数 QString::contains()2.3 函数 QString::toInt()2.4 函数 QString::compare()2.5 将 QString 转换…

RS232引脚方向及意义与接线参考

RS232引脚方向及定义编号引脚意义方向作为IO使用说明1CD载波检测(Carrier Detect)计算机《调制解调器输入调制解调器通知计算机有载波被侦测到2RXD接收(Receive)计算机《调制解调器 接收数据3TXD发送(Transmit)计算机》调制解调器 发送数据4DTR数据终端设备(DTE)备好(Data Te…

揭秘豆瓣网站爬虫:利用lua-resty-request库获取图片链接

介绍 在网络数据采集领域&#xff0c;爬虫技术在图片获取方面具有广泛的应用。而豆瓣网站作为一个内容丰富的综合性平台&#xff0c;其图片资源也是广受关注的热点之一。本文将聚焦于如何利用Lua语言中的lua-resty-request库&#xff0c;高效地从豆瓣网站获取图片链接。我们将…

RAG 检索的底座:Milvus Cloud向量数据库

在业界实践中,RAG 检索通常与向量数据库密切结合,也催生了基于 ChatGPT + Vector Database + Prompt 的 RAG 解决方案,简称为 CVP 技术栈。这一解决方案依赖于向量数据库高效检索相关信息以增强大型语言模型(LLMs),通过将 LLMs 生成的查询转换为向量,使得 RAG 系统能在向…

MAcA-PEG-MAcA,Methacrylamide-PEG-Methacrylamide可作为高分子链转移剂或高分子乳化剂使用

【试剂详情】 英文名称 MAcA-PEG-MAcA&#xff0c; Methacrylamide-PEG-Methacrylamide 中文名称 聚乙二醇二苯甲醛&#xff0c; 苯甲醛-聚乙二醇-苯甲醛 外观性状 由分子量决定&#xff0c;固体或者液体。 分子量 0.4k&#xff0c;0.6k&#xff0c;1k&#xff0c;2k&am…

发电机组远程管理,提升管控力,降低运维成本

发电机组是指发电机发动机以及控制系统的总称&#xff0c;用来把发动机提供的动能转化为电能。它通常由动力系统、控制系统、消音系统、减震系统、排气系统组成。发电机组远程管理系统利用物联网技术与PLC远程控制模块集成解决方案&#xff0c;在提高发电机组的运行效率、降低运…

用于YouTube推荐的深度神经网络YouTube DNN

这篇论文是最近参加组会看的一篇新论文&#xff0c;论文虽然是2016年出的论文&#xff0c;但是它是YouTube发表的&#xff0c;且是应用在YouTube这样超级大的平台上的一篇工业界的推荐系统的论文&#xff0c;我读完之后也觉得论文有一些可取之处的&#xff0c;所以和大家分享一…

【Chrome实用命令笔记】

文章目录 Chrome实用命令笔记1、chrome基本介绍2. 打开开发者工具&#xff08;DevTools&#xff09;方法一&#xff1a;快捷键方法二&#xff1a;右键菜单方法三&#xff1a;浏览器设置 2. 开发者工具面板Elements面板Console面板Sources面板Network面板Performance面板Memory面…