数据库精选题(三)(SQL语言精选题)(按语句类型分类)

news2024/11/24 4:18:04

🌈 个人主页:十二月的猫-CSDN博客
🔥 系列专栏: 🏀数据库

💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光


 目录

前言

创建语句

创建表

创建视图

创建索引

插入语句

一次插入一条

一次插入多条

删除语句 

修改语句

修改表结构

修改表格内容

查询语句 

分类一:没有任何

分类二:至少有一个 

分类三:满足条件一同时满足条件二但不满足条件三

分类五:模糊查询%的使用

分类五:间接关系(祖孙关系、间接先行课关系)

分类六:找出所有

分类七:存在重复项只记录一次(学生多次考试只取最高成绩)

分类八:存在具体数值要求+分组处理

分类九:超过所有

分类十:聚集函数嵌套的转化方法

分类十一:带条件更新

分类十二: 同表格不同角色匹配问题

 总结 


前言

数据库的操作无非就是增、删、改、查+创建

接下来,我将从以上五个角度来对SQL精选题进行分类,并总结相应解法

创建语句

数据库中创建主要包括:创建表、创建视图、创建索引、创建用户

创建的方式有:直接创建(直接指定创建内容)、间接创建(利用已有视图或表创建)

创建表

直接创建:

create table table1(
    sid char(12) not null,
    name varchar(10) not null,
    age int,
    birthday date,
    credit numeric(4,1)
    primary key(sid)
    foreign key(name) references student_name(name)
);

先设定属性;再设定主键、外键等键值 

间接创建:

create table table1 as
select sid,cid,score
from student
where sid='202100202052'

两者比较: 

直接创建:需要用小括号确定表结构范围(注意逗号、分号、括号

间接创建:需要用as,但是会根据查询结果直接创建,不需要用()确定范围(啥也没有

创建视图

视图的创建使用as间接创建,因为视图并不实际存储于数据库中,所以是基于已有表进行的

直接创建:

视图不能直接定义创建。因为视图并不存储在数据库中,而是基于已有表进行的创建

间接创建:

create view test3 as
select sid,cid,pub.course_name,score
from pub.student natural join pub.student_course natural join pub.course
where pub.student_name='李龙'

两者比较: 

视图的创建只能用间接创建法:利用as、不用加()限制范围 

创建索引

索引的创建没有直接创建和间接创建的说法,索引只能定义创建,不能根据已有索引创建

create index index1 on student(sid,name)

插入语句

插入语句分为:一次插入一条记录、一次插入多条记录两种类型

一次插入一条

insert into student values(202100202052,'李华',to_date('19950303 101010','yyyymmdd hh24miss'))

一次插入多条

insert all
    into test1_course values('300002','数据库','300001',2.5)
    into test1_course values('300001','数据结构',null,2)
select * from dual

两者比较:  

1、insert into

2、insert all into

3、date类型的插入利用to_data('20080715 101010‘,‘yyyymmdd hh24miss’)

删除语句 

1、删除语句和插入语句的格式是相对应的

2、本部分的精选题重点在于各种全新的语句用法(不仅仅限于and、from、where等一般语句)

总结如下:

  • regexp_like(sid,'^[0-9]+$')
  • where score between 0 and 100
  • length(sid)
  • like '% %'
  • where 后面跟(cid,tid)这种整体匹配语句

删除语句对应的是插入语句(一个是增一个删),因此两者的语法也类似。insert into和delete from相匹配

题目一:

删除表中的学号不全是数字的那些错误数据,学号应该是数字组成,不能够包含字母空格等非数字字符。方法之一:用substr函数,例如Substr(sid,1,1)返回学号的第一位,判断是否是数字。

delete from test3_01
where sid not in
	(select sid
	from test3_01
	where regexp_like(sid, '^[0-9]+$'))

题目二:

 删除表中的性别有错误的那些错误数据(性别只能够是“男”、“女”或者空值)。

delete from test3_03
where sex <> '男' and sex <> '女' and sex is not null

题目三:

删除表中的院系名称有空格的、院系名称为空值或者院系名称小于3个字的那些错误数据。

delete from test3_04 
where dname like '% %' or
dname is null or
length(dname) < 3

题目四: 

删除其中的错误数据,错误指如下情况:课程号和教师编号在教师授课表pub.teacher_course中不同时存在的,即没有该教师教该课程; 

delete from test3_08 
where (cid, tid) not in(
    select cid, tid
    from pub.teacher_course
)

题目五:

 删除其中的错误数据,错误指如下情况:成绩数据有错误(需要先找到成绩里面的错误)。

delete from test3_09
where score not between 0 and 100

修改语句

在创建数据库表格并往表格内插入数据后,我们可能还需要对表格进行修改,因此修改语句也是必要的。修改语句包括:修改表结构、修改表格内容

修改表结构

alter table test4_02
add avg_score numeric(3,1)
alter table test4_02
drop column avg_score 

修改表格内容

update test4_01 S
  set sum_score=(
    select sum(score)
    from pub.student_course T
    where S.sid=T.sid
  )
update test4_07
set sex= replace( sex,'性','')
update test4_10
set age=(
    select (2012-extract (year from birthday))
    from pub.student_42
    where test4_10.sid=sid
)
where test4_10.age is null;

 两者联系及感悟:  

1、只有修改表结构和创建表结构时需要指定table和view

2、修改表格内容时用update以及set函数

3、replace函数常用来update不规范数据

4、extract函数用来提取date类型数据中的year、month、day都可以


重点来啦!!!数据库SQL语言中最难的部分就是查询。数据库查询大约占数据库语言使用的80%(李晖老师说的),所以查询语句写的好/不好对整体数据库性能的影响是很大的

 

查询语句 

编写语句的思考流程:

1、确定要查询的变量

2、根据要查询的变量确定要查询的关系表(哪几个表、是否要自然连接处理等)

3、写查询的条件(最难的部分)

分类一:没有任何

没有任何=完全否定=全集-只要有一个在里面

使用minus实现

找出至少选修了学号为“200900130417”的学生所选修的一门课的学生的学号、姓名(不包含这名同学)。 

select sid,name
from pub.student
where sid in(
    (
        select distinct sid
        from pub.student_course
        where cid in (
            select cid
            from pub.student_course
            where sid='200900130417'
        )
    )
    minus
    (
        select sid
        from pub.student
        where sid='200900130417'
    )
)

分类二:至少有一个 

in:或关系,只要有一个就是满足的

至少有一个=只要一个就满足=或关系

找出至少选修了一门其先行课程号为“300002”号课程的学生的学号、姓名。

 select sid, name
 from  pub.student
 where sid in(
    select sid
    from pub.student_course
    where cid in ( 
        select cid
        from pub.student_course
        where pcid='300002'
    )
)

分类三:满足条件一同时满足条件二但不满足条件三

满足多个条件/不满足多个条件的处理:

1、对于关系集合用minus、intersect来求交并集;

2、对于在where查询条件后的用and、or等来处理

3、一个属性上多条件——》交并集(minus、intersect);多个属性上多条件(and、or)

找出选修了“操作系统”并且也选修了“数据结构”,但是没有选修“程序设计语言”的学生的学号、姓名。

select sid,name
  from pub.student
  where sid in
  (
    (
      select sid
      from pub.student_course
      where cid=(
        select cid
        from pub.course
        where name='操作系统'
      )
    )
    intersect
    (
      select sid
      from pub.student_course
      where cid=(
        select cid
        from pub.course
        where name='数据结构'
      )
    )
    minus
    (
      select sid
      from pub.student_course
      where cid=(
        select cid
        from pub.course
        where name='程序设计语言'
      )
    )
  )

查询2010级、计算机科学与技术学院、操作系统的学生成绩表,内容有学号、姓名、成绩。

  select sid,name,score
  from pub.student_course natural join pub.student
  where class='2010' and dname='计算机科学与技术学院' and cid=(
    select cid
    from pub.course
    where name='操作系统'
  )

分类五:模糊查询%的使用

%:就是模糊查询;模糊查询与like以及not like绑定使用

条件字符串部分限制、部分自由

查询所有不姓张、不姓李、也不姓王的学生的学号sid、姓名name

select sid,name
from pub.student
where name not like '张%'
and name not like '李%'
and name not like '王%'

分类五:间接关系(祖孙关系、间接先行课关系)

两种方法:

1、利用笛卡尔积实现

2、利用嵌套结构实现

比较和联系:

1、笛卡尔积A*B实现本质就是让A中的每一个元组和B中的每一个元组比较

2、嵌套结构先找出B的所有元组,利用in来将A中的每个元组和B的每个元组比较比较

找出有间接先行课的所有课程的课程号、课程名称。

select cid ,name
from pub.course
where fcid in (
  select cid
  from pub.course
  where fcid is not NULL
)

已知所有的父子关系fstable表,找出里面的爷孙关系的名字

select s1.father,s2.son
from fstable s1,fstable s2
where s1.son=s2.father

分类六:找出所有

所有关系:用除运算实现,除运算找出的就是集合和其子集的关系(所有关系

在SQL中不能使用除运算,改为用not exists实现

找出选修了所有课程的学生的学号、姓名。

select sid,name
from pub.student
where not exists(
  (
    select cid
    from pub.course
  )
  minus
  (
    select cid
    from pub.student_course
    where pub.student_course.sid=pub.student.sid
  )
)

分类七:存在重复项只记录一次(学生多次考试只取最高成绩)

表格1存在重复项,想要计算没有重复项参与的表格1中的数据

1、找中介人:找到一个不存在重复项的表格2,利用表格2实现对表格1的剔除工作。此时,表格2作用为:剔除者、观察者;表格1作用为:实际要找寻的资料原件

使用update语句,利用pub.student_course、pub.course,统计 “总学分”;

(这是需要注意:成绩及格才能够计算所得学分,一门课多个成绩都及格只计一次学分)

update test4_03 S
  set sum_credit=(
    select sum(credit)
    from pub.course
    where cid in(
      select distinct cid
      from pub.student_course SC
      where S.sid=SC.sid
      and SC.score>=60
    )
  )

分类八:存在具体数值要求+分组处理

分组处理:需要用表中的某一个元素将其他信息聚合起来(出版社/会员)

对于每个出版商,找出每个借了该出版商五本书以上的会员的编号和姓名

select memb_no,name
from member m
where memb_no in(
  select memb_no
  from borrowed bw,book bk
  where bw.isbn=bk.isbn
  group by publisher,memb_no
  having (count(*)>5)
)

having:后面跟的应该是bool类型的表达式结果,having和where一样是筛选条件

having的作用范围:分组后的组内

分类九:超过所有

超过所有=超过最大值——》利用max来求解最大值

 找出所有收入超过 "小型银行公司 "每个员工的员工 ID

select id
from work
where salary >
(
  select max(salary)
  from works
  where company_name='Small Bank Corporation'
)

假设一个公司可以在好几个城市有分部。找出位于“Small Bank Corporation”所在城市的所有公司(company_name是主键,所以一家公司只能在一个城市)

Select company_name
From Company
Where city in (
  select city
  From company
  Where company_name = 'Small Bank Corporation'
)

上题的难度在于对题目的理解:位于“Small Bank Corporation”所在城市。

1、找出“Small Bank Corporation”的城市

2、利用in来实现位于动作

分类十:聚集函数嵌套的转化方法

有时候我们会遇到需要使用两个聚集函数的情况,但是在一个关系中聚集函数是不能够嵌套使用的,因此需要用别的方法来代替聚集函数嵌套使用

常见的嵌套场景:count+max(求count元组数中的最大值)

找出雇员最多的公司名称(或公司名称、在最多员工数相同的情况下)的公司名称

1、首先需要求解每个公司的雇员——需要count聚集函数

2、求解雇员数最大的公司——需要max函数对count结果使用

转化:雇员最多=雇员比最多的还多(count+max)=雇员比所有的都多(count+all),成功避开聚集函数的嵌套

select company_name
from works
group by company_name
having count(id)>=all(
  select count(id)
  from works
  group by company_name
)

找出工资总额最小的公司

select company_name
from works
group by company_name
having (
  sum(salary)<all(
    select sum(salary)
    from works
    group by company_name
  )
)

分类十一:带条件更新

存在一类更新是带有条件的,不同条件下的元组更新的方式也不同

更新无非增加/减少

为了防止非法更新两次:需要满足增加时先加大的,减少时先减少的

给 "第一银行公司 "的每位经理加薪 10%,除非其工资超过 100000 美元。在这种情况下,只加薪 3%(这两个update的顺序不可以更换)(增加时先加大的,减少时先减少的;防止有的记录被操作两次)

update works as T
set T.salary=t.salary*1.03
where works.id in (
  select id
  from manages
)
and salary>100000
and company_name='First Bank Corporation'
 
update works as T
set T.salary=t.salary*1.1
where works.id in (
  select id
  from manages
)
and salary<100000
and company_name='First Bank Corporation'

分类十二: 同表格不同角色匹配问题

匹配问题=比较是否相等=比较问题

比较只能发生在两个关系模式之间

1、此时两个角色进行比较,两个角色对应的表格是同一个

2、因此拿相同关系模式当作两个不同的关系模式做笛卡尔积,再比较结果

3、笛卡尔后判断相应的属性是否符合要求

查找与其经理住在同一城市同一条街上的每位员工的 ID 和姓名

select e.id,e.person_name
from employee e natural join managers m,employee e2
where m.manager_id=e2.id and e.city=e2.city and e.street=e2.street

简化写法:

SELECT e.id, e.person_name
FROM employee e
JOIN managers m ON e.id = m.id
JOIN employee e2 ON m.manager_id = e2.id
WHERE e.city = e2.city AND e.street = e2.street;

 总结 

本文的所有知识点、图片均来自《数据库系统概念》(黑宝书)、山东大学李晖老师PPT。不可用于商业用途转发。

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

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

相关文章

【机器学习】基于Softmax松弛技术的离散数据采样

1.引言 1.1.离散数据采样的意义 离散数据采样在深度学习中起着至关重要的作用&#xff0c;它直接影响到模型的性能、泛化能力、训练效率、鲁棒性和解释性。 首先&#xff0c;采样方法能够有效地平衡数据集中不同类别的样本数量&#xff0c;使得模型在训练时能够更均衡地学习…

开启声音的奇幻之旅:AI声音变换器的魔法秘籍与创意应用

AI视频生成&#xff1a;小说文案智能分镜智能识别角色和场景批量Ai绘图自动配音添加音乐一键合成视频https://aitools.jurilu.com/这个充满科技魔力的时代&#xff0c;AI Voice Changer 就像一把神奇的钥匙&#xff0c;能为我们打开声音的魔法之门。今天&#xff0c;就让我带你…

在线教育系统源码入门:教育培训小程序开发全流程

本篇文章&#xff0c;笔者将详细介绍在线教育系统源码的入门知识&#xff0c;并带领大家了解教育培训小程序的开发全流程。 一、在线教育系统的基本概念 一个完整的在线教育系统应具备以下几个模块&#xff1a; 用户管理 课程管理 教学互动 支付模块 数据统计 二、开发工…

【开发】内网穿透ztncui搭建私有节点

文章目录 写在前面一键部署ztnuci记录后续 写在前面 前面搭建moon节点转发的确会降低延迟&#xff0c;但是总有出现moon节点解析不成功的例子&#xff0c;于是疯狂寻找答案是为什么&#xff1f;终于在知乎上找到这样一个答案。 一键部署ztnuci 参考这篇很完善的教程和贴心的…

小i机器人:总负债5.31亿,员工数量在减少,银行借款在增加,净利润已下降-362.68%

小i机器人:总负债5.31亿,员工数量在减少,银行借款在增加,总收入在增长,净利润已下降-362.68% 来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 目录 一、小i机器人公司介绍 二、小i机器人过去20年的发展历程和取得的成就 三、小i机器人的产品和技术架构 四、小i机器人…

动手学深度学习(Pytorch版)代码实践 -卷积神经网络-24深度卷积神经网络AlexNet

24深度卷积神经网络AlexNet import torch from torch import nn import liliPytorch as lp import liliPytorch as lp import matplotlib.pyplot as pltdropout1 0.5 #Alexnet架构 net nn.Sequential(nn.Conv2d(1, 96, kernel_size11, stride4, padding1),nn.ReLU(),nn.MaxPo…

29-Linux--守护进程

一.基础概念 1.守护进程&#xff1a;精灵进程&#xff0c;在后台为用户提高服务&#xff0c;是一个生存周期长&#xff0c;通常独立于控制终端并且周期性的执行任务火处理事件发生 2.ps axj&#xff1a;查看守护进程 3.进程组&#xff1a;多个进程的集合&#xff0c;由于管理…

# 消息中间件 RocketMQ 高级功能和源码分析(十一)

消息中间件 RocketMQ 高级功能和源码分析&#xff08;十一&#xff09; 一、消息中间件 RocketMQ 源码分析&#xff1a; 拉取消息长轮询机制 1、消息拉取长轮询机制分析 RocketMQ 未真正实现消息推模式&#xff0c;而是消费者主动向消息服务器拉取消息&#xff0c;RocketMQ …

LeetCode80. 删除有序数组中的重复项 II题解

LeetCode80. 删除有序数组中的重复项 II题解 题目链接&#xff1a; https://leetcode.cn/problems/remove-duplicates-from-sorted-array-ii/ 题目描述&#xff1a; 给你一个有序数组 nums &#xff0c;请你 原地 删除重复出现的元素&#xff0c;使得出现次数超过两次的元素…

基于uniapp的h5接入企业微信客服在线聊天

首先说下企业微信接入场景,支持的接入场景有以下几种,基本上涵盖了微信生态大部分场景: 接入步骤 1.创建企业微信号 按照官方操作步骤注册,需要注意的是未认证仅支持接入100人,已认证支持接入2000人. 2.创建客服账号 每个客服账号支持配置人工或是机器人或是人工机器人回复…

艾尔登法环黄金树幽影/ELDEN RING Shadow of the Erdtree(全DLC)

百度网盘 https://pan.baidu.com/s/1ulKiNQdVtV5dto-Vm7k4IA 提取码&#xff1a;yqrs 游戏介绍 《艾尔登法环》是一款以正统黑暗奇幻世界为舞台的动作RPG游戏。走进辽阔的场景与地下迷宫探索未知&#xff0c;挑战困难重重的险境&#xff0c;享受克服困境时的成就感吧。…

【单元测试】Spring Boot 的测试库

Spring Boot 的测试库 1.了解回归测试框架 JUnit2.了解 assertThat3.了解 Mockito4.了解 JSONPath5.测试的回滚 单元测试&#xff08;unit test&#xff09;是为了检验程序的正确性。一个单元可能是单个 程序、类、对象、方法 等&#xff0c;它是应用程序的最小可测试部件。 单…

如何修复“AI的原罪”

如何修复“AI的原罪” 上个月&#xff0c;《纽约时报》声称&#xff0c;科技巨头OpenAI和谷歌不顾服务条款和版权法的禁止&#xff0c;将大量YouTube视频转录成文本&#xff0c;并将其用作人工智能模型的额外训练数据&#xff0c;从而进入了版权灰色地带。《纽约时报》还援引Me…

HTML(18)——浮动

标准流 标准流也叫文档流&#xff0c;指的是标签在页面中默认的排布规则&#xff0c;例如&#xff1a;块元素独占一行&#xff0c;行内元素可以一行显示多个 浮动 作用&#xff1a;让块级元素水平排列 属性名&#xff1a;float 属性值 left&#xff1a;左对齐right&#…

高通安卓12-ADB操作

1.ADB安装 从网上下载一个adb工具 如&#xff1a; https://dl.google.com/android/repository/platform-tools_r31.0.2-windows.zip 解压出来 增加一个环境变量 查看安装情况 2.设备连接 从网上下载ADB工具 1.进入命令行&#xff0c;查询设备状态 adb devices 2.进入shel…

【硬件开发】共模电感

为什么电源无论直流还是交流的输入端都需要一个共模电感 图中L1就是共模电感&#xff0c;长下面这个样子&#xff0c;两侧的匝数&#xff0c;线径和材料都是一模一样的 共模电感的作用是为了抑制共模信号 抑制共模信号工作原理 http://【共模电感是如何抑制共模信号的】https…

视频讲解|基于模型预测算法的含储能微网双层能量管理模型【mpc】

1 主要内容 该讲解视频对应的免费程序链接为【防骗贴】基于模型预测算法的含储能微网双层能量管理模型&#xff0c;主要做的是一个微网双层优化调度模型&#xff0c;微网聚合单元包括风电、光伏、储能以及超级电容器&#xff0c;在微网的运行成本层面考虑了电池的退化成本&…

AT32F435 入门使用

AT32F435 入门使用 &#x1f516;这里以AT32F435RGT7作为测试对象&#xff0c;创建基于Keil平台编译的代码工程。&#x1f4cd;相关篇《基于AT32_Work_Bench配置AT32工程》 ✨由于AT32F435RGT7&#xff08;LQFP-64封装&#xff09;引脚与STM32F405RGT6TR引脚兼容程度&#xff1…

AI周报(6.16-6.22)

1 不是AI而是逐帧视觉特效-2024年D&AD黑铅笔奖Women’s Football Women’s Football在2024年D&AD广告类Digital & Social类别中获得了黑铅笔奖&#xff0c;并在Film类别中获得了黄铅笔奖 原来那些超燃的画面&#xff0c;是把女足比赛的画面“换脸”成了男运动员。…

css 动画

transform的3D动画 3D形变函数会创建一个合成层来启用GPU硬件加速 translate transform: translateY(100px);transform: translateX(100px);transform: translateZ(100px);transform: translate3d(100px,100px,100px); // x,y,z的简写rotate deg弧度 transform: rotateX(-40…