数据库 |试卷1试卷2

news2025/1/20 22:44:13

1.数据库语言四大语句

4.四大类(DDL、DML、DQL、DCL)_中度ddl-CSDN博客

数据定义(data defination language)

查询、创建、删除、使用

#查询所有数据库
show databases;

#查询当前数据库
select database();

#创建数据库
create database [if not exists] 数据库名 [default charset 字符集] [collate 排序规则];

#删除数据库
drop database [if exists] 数据库名;

#使用数据库
use 数据库名;

数据操作(data manipulation language)

插入、修改、删除

#给指定字段添加数据
insert into 表名(字段名1,字段名2)
values
(值1,值2);

#修改数据
update 表名 
set 字段名1 = 值1,字段名2 = 值2 
[where 条件];

#删除数据
delete 
from 表名 
[where 条件];


数据查询(data query language)

#查询多个字段
select 字段1,字段2,字段3 
from 表名;

#查询全部字段
select * 
from 表名;

数据控制(data control language)

权限控制

#查询权限
show grants for '用户名'@'主机名';

#授予权限
grant 权限列表 on 数据库.表名 to '用户名'@'主机名';

#撤销权限
revoke 权限列表 on 数据库.表名 from '用户名'@'主机名';

2.把对关系SPJ的属性QTY的修改权授予用户李勇的T-SQL语句是(    )


正确答案: C   你的答案: 、B (错误)
GRANT QTY ON SPJ TO '李勇'
GRANT UPDATE(QTY) ON SPJ TO '李勇'
GRANT UPDATE (QTY) ON SPJ TO 李勇
GRANT UPDATE ON SPJ (QTY) TO 李勇

grant update (列名) on 表名 to 用户

它错误地在用户名周围使用了单引号


3.用于识别同一实体集中的两个不同实体值为什么是主码而不是主属性

  • 单一的主属性可能不足以唯一标识一个实体,因为可能存在多个具有相同主属性值的记录。
  • 主码(由一个或多个主属性组成)能够确保在实体集中每个实体的唯一性,从而避免了数据冲突和混淆。
  • 使用主码可以方便地建立表与表之间的关联关系,实现数据的关联查询和完整性维护。

 4.什么是死锁以及死锁的解决办法?

死锁产生的原因及解决方法_死锁的产生机制-CSDN博客

死锁是多个事务竞争同一数据对象而处于永远等待的情况

解决办法:

1.加锁顺序(按照一定的顺序加锁)

2.加锁时限(线程获取锁加上时限,超时就放弃获取锁,并释放自己占有的锁)

3.死锁监测机制,在一定时间内监测有无死锁


5.五种基本的关系代数运算

选择

投影 


6.解释这段代码的作用:

CREATE TABLE EMP  
(  
    ENO CHAR(4) PRIMARY KEY,  
    ENAME CHAR(20) NOT NULL UNIQUE,  
    BIRTHDAY DATE,  
    SALARY INTEGER DEFAULT(5200) CHECK(SALARY BETWEEN 5000 AND 15000)  
);

这段代码是用于在数据库中创建一个名为 EMP 的表的 SQL 语句。这个表包含以下四个字段(或称为列):

  1. ENO:这是一个 CHAR(4) 类型的字段,用于存储员工的编号。由于它被定义为 PRIMARY KEY,所以这个字段的值必须是唯一的,且不能为 NULL。换句话说,每个员工都有一个唯一的编号,且这个编号不能重复,也不能为空。
  2. ENAME:这是一个 CHAR(20) 类型的字段,用于存储员工的名字。这个字段被标记为 NOT NULL 和 UNIQUENOT NULL 表示这个字段的值不能为空,而 UNIQUE 则表示这个字段的值必须是唯一的,不能有重复的名字。
  3. BIRTHDAY:这是一个 DATE 类型的字段,用于存储员工的生日。这个字段没有特别的约束,所以它可以包含任何有效的日期值,或者为空(如果数据库支持 NULL 值的话)。
  4. SALARY:这是一个 INTEGER 类型的字段,用于存储员工的薪水。它被设置为有一个默认值 5200,这意味着如果在插入新记录时没有为 SALARY 字段指定值,那么它的值将被自动设置为 5200。此外,SALARY 字段还有一个 CHECK 约束,确保它的值在 5000 和 15000 之间(包括这两个值)。

总的来说,这段代码定义了一个 EMP 表,该表用于存储员工的基本信息,包括编号、名字、生日和薪水。其中编号和名字是唯一的,薪水有一个默认值,并且薪水值必须在一定的范围内。


7.日期的sql语句

between '1999-10-1' and '2000-12-31'

 SQL 语句查询出生日期在 1999-10-1 至 2000-12-31 日之间的所有学生

SELECT *
FROM S  
WHERE SBIRTH BETWEEN '1999-10-01' AND '2000-12-31';

8.删除语句

删除计算机学院不及格学生的选课记录

DELETE FROM SC    
WHERE SID IN (    
    SELECT S.SID    
    FROM S, SC    
    WHERE S.SID = SC.SID AND S.SCHOOL = '计算机学院' AND SC.GRADE < 60  
);

9.升序和不及格查询

1. 查询学生的成绩信息,按照学号升序显示

SELECT SID, SNAME, CID, GRADE  
FROM S, SC  
WHERE S.SID = SC.SID  
ORDER BY S.SID ASC;

 2. 查询有不及格(小于 60 分)的学生姓名

SELECT DISTINCT SNAME  
FROM S, SC  
WHERE S.SID = SC.SID AND GRADE < 60;

3. 删除计算机学院不及格学生的选课记录

DELETE FROM SC  
WHERE SID IN (  
    SELECT S.SID  
    FROM S, SC  
    WHERE S.SID = SC.SID AND SCHOOL = '计算机学院' AND GRADE < 60  
);

10.火车主码

在数据库设计中,主码(也称为主键)是用于唯一标识表中每一行(或称为记录)的一组属性或字段。这些属性或字段的组合在表中必须是唯一的,且不应包含空值(NULL)

A. 车次
仅使用“车次”作为主码可能不足以唯一标识一个“列车运营”实体,因为同一车次可能在不同的日期运行。

B. 日期
仅使用“日期”作为主码同样不足以唯一标识一个“列车运营”实体,因为同一天可能有多个车次运行。

C. 车次+日期
使用“车次”和“日期”的组合可以唯一标识一个特定的“列车运营”实体,因为在一个给定的日期,车次是唯一的。

D. 车次+情况摘要
“情况摘要”通常是一个描述性的字段,用于记录列车运营过程中的一些特殊情况或事件。它可能包含文本信息,并且很可能不是唯一的,甚至可能为空。因此,使用“车次”和“情况摘要”的组合不能作为唯一标识一个“列车运营”实体的主码。

基于以上分析,选项C(车次+日期)是正确的,因为它提供了一个足够唯一且符合主码定义的组合。选项D不符合主码的要求,因为它可能不是唯一的,并且可能包含空值。


11.左、右连接,全连接

图解数据库左连接、右连接、内连接、外连接、全连接的区别_左连接,右连接,内连接,外连接的区别-CSDN博客 

在这个问题中,我们需要列出所有学生的住宿情况,包括那些不住宿的学生,以及所有宿舍的分配情况,包括那些空闲的床位。为了实现这个需求,我们需要使用一种联接方式,该联接方式能够返回左表(学生)和右表(宿舍)中的所有记录,无论它们是否在对方表中有匹配项。

现在我们来分析每个选项:

A. 全外联接(Full Outer Join):这个联接会返回左表和右表中的所有记录。如果某一边没有匹配项,则结果集中对应的字段将包含NULL。这正是我们需要的,因为它会列出所有学生和所有宿舍,无论它们是否有匹配项。

B. 左外联接(Left Outer Join):这个联接会返回左表中的所有记录,以及右表中匹配的记录。如果左表中的某条记录在右表中没有匹配项,则结果集中对应的右表字段将包含NULL。但它不会返回右表中没有匹配项的记录,也就是空闲的床位

C. 右外联接(Right Outer Join):这个联接与左外联接相反,会返回右表中的所有记录,以及左表中匹配的记录。但它不会返回左表中没有匹配项的记录,也就是不住宿的学生。

D. 自然联接(Natural Join):自然联接是基于两个表中所有同名列的值进行等值比较,并返回匹配的记录。它不会返回没有匹配项的记录,因此不适用于这个场景。

综上所述,为了列出所有学生住宿和宿舍分配的情况,包括没有住宿的学生和空闲的床位,我们应该选择全外联接(A)。


12.最小关系系统(不懂)

 13.转储的冗余数据:日志文件、数据库后备副本

 14.关系模型组成

关系数据结构

关系操作

关系完整性约束

15.在Student表的Sname列上建立一个唯一索引的SQL语句为:

建立唯一索引的语法:create unique index 别名 on 表名(列)

CREATE   UNIQUE INDEX  Stusname ON student(Sname)


16.!=ALL 与NOT IN 等价

使用 != ALL 时,你实际上是在说:“这个值必须不等于我给出的所有值”。
如果你想要从表A中选择那些其value列的值不等于表B中所有value值的记录,你可以使用!= ALL,如下所示:

SELECT * FROM A  
WHERE A.value != ALL (SELECT B.value FROM B);


17.E-R冲突---结构、命名、属性冲突

18.可串行性是并发事务的准则

19.事务是DBMS的基本单位

20. 试述关系模型的参照完整性规则?

    答:参照完整性规则:若属性(或属性组)F是基本关系R的外码,它与基本关系S的主码Ks相对应(基本关系R和S不一定是不同的关系),则对于R中每个元组在F上的值必须为:取空值(F的每个属性值均为空值)或者等于S中某个元组的主码值。


21. 试述视图的作用?

(1)视图能够简化用户的操作。

(2)视图使用户能以多种角度看待同一数据。

(3)视图对重构数据库提供了一定程度的逻辑独立性。

(4)视图能够对机密数据提供安全保护。


22.  登记日志文件时必须遵循什么原则?

        登记日志文件时必须遵循两条原则:

        (1)登记的次序严格按并发事务执行的时间次序。

        (2)必须先写日志文件,后写数据库。


23.联系的属性要写到1:n的n的关系模式里面

n:m的联系也要加上自己的属性

 


24.为什么广义笛卡尔积不属于专门的关系运算?

并、差、积、选择、投影(五种基本的关系运算)

常见的关系运算包括选择(Selection)、投影(Projection)、并集(Union)、交集(Intersection)、差集(Difference)和连接(Join)等。 


25.数据库系统最重要的软件:DBMS(数据管理系统),最重要的用户(DBA)

26.实体完整性:关系的主属性都不能取空值 

27.“数据”、“数据库”、“数据库管理系统”和“数据库系统”

数据:描述现实世界的事物的符号记录

数据库:长期存储在计算机内,有组织、可共享的组织的集合

数据库管理系统:位于用户与操作系统间的具有数据定义、操作、控制、查询、数据库建立和管理数据库的重要软件

数据库系统:数据库系统是由DB、DBMS(及其应用开发工具)、(DBAP)应用程序和(DBA)数据库管理员组成的存储、管理、维护数据的系统

【数据库】数据、数据库、数据库管理系统、数据库系统_系统的数据管理逻辑-CSDN博客


28.数据库系统的故障

事务故障

介质故障

系统故障 


29.视图和基本表的联系和区别

视图是由一个或者多个基本表导出,它与基本表不同的是,数据库只存放视图的定义,而不存放视图对应的数据,一旦基本表的数据发生改变,从视图查询到的数据也随之改变

视图一经定义就可以跟基本表一样查询和删除,也可以在视图上新建视图,但是对视图的更新有限制

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

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

相关文章

利用DeepFlow解决APISIX故障诊断中的方向偏差问题

概要&#xff1a;随着APISIX作为IT应用系统入口的普及&#xff0c;其故障定位能力的不足导致了在业务故障诊断中&#xff0c;APISIX常常成为首要的“嫌疑对象”。这不仅导致了“兴师动众”式的资源投入&#xff0c;还可能使诊断方向“背道而驰”&#xff0c;从而导致业务故障“…

【CT】LeetCode手撕—46. 全排列

目录 题目1- 思路2- 实现⭐46. 全排列——题解思路 3- ACM实现 题目 原题连接&#xff1a;46. 全排列 1- 思路 模式识别 模式1&#xff1a;不含重复数字的数组 nums ——> 任意顺序 可能的全排列 ——> 回溯模式2&#xff1a;全排列 ——> 排列问题&#xff0c;不同…

PLC通过Profibus协议转Modbus协议网关接LED大屏通讯

一、背景 Modbus协议和Profibus协议是两种常用于工业控制系统的通信协议&#xff0c;它们在自动化领域中起着重要的作用。Modbus是一种串行通信协议&#xff0c;被广泛应用于各种设备之间的通信&#xff0c;如传感器、执行器、PLC等。而Profibus则是一种现场总线通信协议&…

可以把 FolkMQ 内嵌到 SpringBoot3 项目里(可内嵌的消息中间件)

之前发了《把 FolkMQ 内嵌到 SpringBoot2 项目里&#xff08;比如 “诺依” 啊&#xff09;》。有人说都淘态了&#xff0c;有什么好内嵌的。。。所以再发个 SpringBoot3 FolkMQ 是一个 “纯血国产” 的消息中间件。支持内嵌、单机、集群、多重集群等多种部署方式。 内嵌版&am…

SysTools MailXaminer: 电子邮件取证调查中的链接分析和时间线分析

天津鸿萌科贸发展有限公司是 SysTools 系列软件的授权代理商。 SysTools MailXaminer 电子邮件取证软件提供全面强大的解决方案&#xff0c;通过简化的操作&#xff0c;从电子邮件客户端、网络邮箱服务器、磁盘镜像、Skype 通讯工具中解密并搜索证据。软件对调查工作的每一阶段…

volatile原理

volatile内存语义 volatile是java提供的一种轻量级的同步机制&#xff0c;在并发编程中&#xff0c;它也扮演着比较重要的角色。一方面volatile不会造成上下文切换的开销&#xff0c;另一方面它又不能像synchronized那样保证所有场景下线程安全&#xff0c;因此必须在合适的场…

滑动窗口练习1-长度最小的子数组

1.题目链接&#xff1a;209.长度最小的子数组 2.题目描述&#xff1a; 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;并返回其长度。如果不存在符合条…

【C++】#20,#21

#20类和对象 #include <iostream>using namespace std;class Box{public: //公有 double length; //ctrle复制本行 double width;double height;void getVolume(){ //方法带&#xff08;&#xff09; cout<<"盒子体积为&#xff1a;"<<le…

聊聊redis中的有序集合

写在文章开头 有序集合(sorted set)是redis中比较常见的数据库结构&#xff0c;它不仅支持O(logN)界别的有序的范围查询&#xff0c;同时也支持O(1)级别的单元素查询&#xff0c;基于此问题&#xff0c;本文就将从redis源码的角度分析一下有序集合的设计与实现。 Hi&#xff0…

黄仁勋最新对话:未来互联网流量将大幅减少,计算将更多即时生成

黄仁勋表示&#xff0c;未来随着设备上运行的小语言模型变得更加上下文化和生成化&#xff0c;互联网流量将大幅减少&#xff0c;计算将更多地即时生成&#xff0c;这将极大地节省能源&#xff0c;使计算模型发生根本性转变。 要点 1、黄仁勋强调生成式AI正以指数速度增长&…

C++ 65 之 模版的局限性

#include <iostream> #include <cstring> using namespace std;class Students05{ public:string m_name;int m_age;Students05(string name, int age){this->m_name name;this->m_name age;} };// 两个值进行对比的函数 template<typename T> bool …

APS计划排程系统如何打破装备使用约束

APS计划排程系统是离散制造型企业在计划控制方向的重要支撑&#xff0c;它提供的是交期预测、订单排产计划、物料采购计划、人力分配计划等等。近些几年来&#xff0c;多品种、小批量、多订单的生产模式&#xff0c;让企业的计划员应接不暇、疲累不堪&#xff0c;传统的人工经验…

js语法---理解防抖原理和实现方法

什么是防抖&#xff08;节流&#xff09; 在实际的网页交互中&#xff0c;如果一个事件高频率的触发&#xff0c;这会占用很多内存资源&#xff0c;但是实际上又并不需要监听触发如此多次这个事件&#xff08;比如说&#xff0c;在抢有限数量的优惠券时&#xff0c;用户往往会提…

白鲸开源CEO郭炜受邀参加第二届软件创新大会,探讨开源与AI融合实践下的商业模式创新

6月13日至6月14日&#xff0c;第二届软件创新发展大会在武汉光谷正式拉开帷幕。此次大会由武汉市人民政府、湖北省经济和信息化厅主办&#xff0c;国家工业信息安全发展研究中心、武汉市经济和信息化局、武汉东湖新技术开发区管理委员会共同承办&#xff0c;旨在贯彻落实国家软…

零基础入门学用Arduino 第四部分(二)

重要的内容写在前面&#xff1a; 该系列是以up主太极创客的零基础入门学用Arduino教程为基础制作的学习笔记。个人把这个教程学完之后&#xff0c;整体感觉是很好的&#xff0c;如果有条件的可以先学习一些相关课程&#xff0c;学起来会更加轻松&#xff0c;相关课程有数字电路…

笔记-python里面的xlrd模块详解

那我就一下面积个问题对xlrd模块进行学习一下&#xff1a; 1.什么是xlrd模块&#xff1f; 2.为什么使用xlrd模块&#xff1f; 3.怎样使用xlrd模块&#xff1f; 1.什么是xlrd模块&#xff1f; ♦python操作excel主要用到xlrd和xlwt这两个库&#xff0c;即xlrd是读excel&…

leetcode118 杨辉三角

给定一个非负整数 numRows&#xff0c;生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和。 示例 1: 输入: numRows 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]]示例 2: 输入: numRows 1 输出: [[1]] public List…

网络安全:探索云安全的最佳实践

文章目录 网络安全&#xff1a;探索云安全的最佳实践引言云安全简介云安全面临的挑战云安全的最佳实践数据加密身份和访问管理定期安全审计 结语 网络安全&#xff1a;探索云安全的最佳实践 引言 在我们之前的文章中&#xff0c;我们讨论了网络安全的多个方面&#xff0c;包括…

【Python特征工程系列】基于方差分析的特征重要性分析(案例+源码)

这是我的第304篇原创文章。 一、引言 方差分析&#xff08;Analysis of Variance&#xff0c;简称ANOVA&#xff09;是一种统计方法&#xff0c;用于比较两个或多个组之间的平均值是否存在显著差异。 方法简介&#xff1a; ANOVA 通过分解总方差为组间方差和组内方差&#x…

鼠情自动监测系统

TH-SH1在农业生产中&#xff0c;鼠害问题一直是困扰农民的一大难题。传统的鼠害防治方法往往依赖于大规模施药或布置捕鼠器等方式&#xff0c;这些方法不仅效率低下&#xff0c;而且容易对环境造成污染。随着科技的不断发展&#xff0c;鼠情自动监测系统应运而生&#xff0c;为…