SQL刷题笔记day5

SQL218题目

我的错误代码:

select de.dept_no,de.emp_no,s.salary
from employees e
join dept_emp de on de.emp_no = e.emp_no
join salaries s on s.emp_no = e.emp_no
where de.dept_no not in dept_manager.dept_no #not in 好像不能直接这样用 这里报错

正确代码

SELECT de.dept_no, de.emp_no, s.salary
FROM dept_emp AS de, salaries AS s
WHERE de.emp_no = s.emp_no 
AND de.to_date = '9999-01-01' 
AND s.to_date = '9999-01-01'
AND s.emp_no NOT IN 
(SELECT emp_no FROM dept_manager dm WHERE dm.to_date = '9999-01-01');

我的代码改正 

select de.dept_no,de.emp_no,s.salary
from employees e
join dept_emp de on de.emp_no = e.emp_no  
join salaries s on s.emp_no = e.emp_no 
where de.emp_no not in (SELECT emp_no FROM dept_manager dm WHERE dm.to_date = '9999-01-01') 

复盘:难点是找非manager员工,涉及not in的用法, not in后面是个范围,而不是dept_manager.dept_no这个某个值。如:

 where subject not in ('Chemistry','Medicine')

如果后面括号只有一个,就要用等于了,如:

where continent = 'South America' 

SQL219题目

我的错误代码

select de.emp_no,m.emp_no as manager_no,
       s1.salary as emp_salary,s2.salary as manager_salary
from dept_emp de 
join dept_manager m on de.dept_no  = m.dept_no 
join salaries s1 on s1.emp_no = de.emp_no and to_date = '9999-01-01'
join salaries s2 on s1.emp_no = m.emp_no and to_date = '9999-01-01'
where s1.salary>s2.salary

正确代码

SELECT es.emp_no,ms.emp_no manager_no,
es.salary emp_salary,ms.salary manager_salary FROM
# es表:员工薪资表 
(SELECT de.dept_no,de.emp_no,s.salary FROM dept_emp de INNER JOIN salaries s
 ON de.emp_no=s.emp_no WHERE s.to_date='9999-01-01') es,

(SELECT dm.dept_no,dm.emp_no,s.salary FROM dept_manager dm INNER JOIN salaries s
 ON dm.emp_no=s.emp_no WHERE s.to_date='9999-01-01') ms
 
WHERE es.dept_no=ms.dept_no 
AND es.salary>ms.salary

理解思路后改正我的代码:

select es.emp_no,ms.emp_no as manager_no,
       es.salary as emp_salary,ms.salary as manager_salary
from 
(select de.emp_no,de.dept_no ,s.salary from dept_emp de join salaries s on s.emp_no = de.emp_no and de.to_date = '9999-01-01')es,
(select m.dept_no,m.emp_no,s.salary from dept_manager m join salaries s on s.emp_no = m.emp_no and m.to_date = '9999-01-01')ms
where es.salary > ms.salary and es.dept_no = ms.dept_no 

复盘:知道要引用两个不同的薪资,分别建立员工和经理的薪资表,不知道咋写,淦!
/*这个正确代码大结构就是:
select ,,,
from ()es,()ms #陌生点就在这里不知道怎么写
where.. 
*/

SQL220题目

我的错误代码

select d.dept_no,d.dept_name,t.title,count(t.title) as count
from departments d
join dept_emp de on d.dept_no = de.dept_no and de.to_date='9999-01-01'
join titles t on t.emp_no = de.emp_no and t.to_date='9999-01-01'
group by d.dept_no # 不知道按照什么进行分组
order by d.dept_no asc,t.title desc

正确代码

select d.dept_no,d.dept_name,t.title,count(t.title) as count
from departments d
join dept_emp de on d.dept_no = de.dept_no and de.to_date='9999-01-01'
join titles t on t.emp_no = de.emp_no and t.to_date='9999-01-01'
group by d.dept_no,t.title # 多字段分组
order by d.dept_no ,t.title #两个都是升序啦(默认也是升序)

复盘:这道题根据 多个字段 进行分组,将三张表内连接,通过 dept_no 和 title 为依据进行分组,然后计算count。因为可能会有下面这种情况:所以还要按照title也进行分组

 SQL223题目

我的代码

select film_id,title 
from film
where ('film_id','title') not in 
(select f.film_id,f.title from film f join film_category fc on f.film_id=fc.film_id )

正确代码1

select film_id,title 
from film
where film_id not in #film_id不应该写成字符串的形式,这里表示的相当于数组名
(select fc.film_id from  film_category fc join category c
 on c.category_id = fc.category_id) #后面这两个表一个是关于类别的

 正确代码2

SELECT film.film_id,film.title
FROM film
LEFT JOIN film_category
on film.film_id = film_category.film_id
where film_category.category_id is null;

复盘:电影如果有分类,那么应该在 类别表category+电影分类表film_category 中有非空信息。

SQL224题目

我的代码

select title,description
from film ,
(select c.name from category c join film_category fc on c.category_id=fc.category_id) mc
where  mc.name='Action'

我这种思路的正确代码

select title ,description 
from film_category ,film
where film_category.category_id = 
( select category_id  from category where name = 'Action') 
and film_category.film_id= film.film_id

不用子查询的直白方法:

select title, description
from film left 
join film_category as fc on film.film_id=fc.film_id
join category as c on c.category_id=fc.category_id
where c.name="Action";

复盘:其实这个题直接3个表连接起来,然后输出就行,但是题目要用子查询。

SQL226题目——拼接字符串(SQLlite平台)

我的代码

select ('first_name'| |'last_name') from employees

题目要求的方法:

select last_name||" "||first_name as name from employees

使用concat函数:

SELECT CONCAT(last_name,' ',first_name) as name from   employees 

 复盘:'first_name'和'last_name'不应该加引号!不是字符串,是相当于数组名的变量!

SQL227题目——创建表

我的代码

CREATE TABLE actor(
actor_id smallint(5)  NOT NULL DEFAULT '0',
first_name	varchar(45) NOT NULL,
last_name	varchar(45) NOT NULL,
last_update	date not null, 
PRIMARY KEY (actor_id))

完美代码:

create table if not exists actor (
    actor_id smallint(5) not null primary key COMMENT'主键id',
    first_name varchar(45) not null COMMENT'名字',
    last_name varchar(45) not null COMMENT '姓氏',
    last_update date not null COMMENT '日期' 
)

复盘:注意创建数据表时,表名和字段名不需要用引号' '括起来。日期是date,其他类型都不变,照着写。 

SQL228——插入数据

我的代码

insert into actor values
('1','PENELOPE','GUINESS','2006-02-15 12:34:33'),
('2','NICK','WAHLBERG','2006-02-15 12:34:33')

复盘:插入的是什么就是什么,不能多复制,哪怕是空格也不能多,因为类型可能不同和报错。

SQL229——插入数据部分已存在的情况

我的代码

insert  ignore into actor
value('3','ED','CHASE','2006-02-15 12:34:33')

复盘:

mysql中常用的三种插入数据的语句

1. insert into - 插入数据

2. replace into - 插入替换数据

3. insert ignore into - 如果已存在,忽略当前新数据

 

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

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

相关文章

在树莓派3B+中下载opencv(遇到的各种问题及解决)

目录 前言 1、删除原版本下新版本 2、python虚拟环境 3、python版本共存换链接——给版本降低 4、烧录之前版本的文件(在清华源中可以找,不用官网的烧录文件就行; 比如:(balenaEtcher)重新烧录有问题…

面试二十六、c++语言级别的多线程编程

一、 多线程编程 ​​​​​ 这里的c语言级别的多线程和linux的有一定的区别,c语言级别提供的多线程比较严格,如果主线程结束了,但是子线程没有结束,进程就会异常终止,而linux不会,会继续执行。 二、模拟卖…

三十、openlayers官网示例解析Double click, Drag and Zoom——第二次点击鼠标拖拽缩放地图效果、取消地图双击放大事件

这篇展示了如何在地图上添加第二次按下鼠标移动鼠标实现拖拽缩放地图效果。 官网demo地址: Double click, Drag and Zoom 官网介绍文字的翻译如下: 示例比较简单,直接贴代码: const map new Map({//添加第二次点击拖拽缩放地图i…

es安装错误Exception in thread “main“ java.nio.file.NoSuchFileException解决方案

docker 启动es出现一下错误的解决方案 Exception in thread “main” java.nio.file.NoSuchFileException: /usr/share/elasticsearch/config/jvm.options Exception in thread "main" java.nio.file.NoSuchFileException: /usr/share/elasticsearch/config/jvm.op…

React@16.x(11)ref

目录 1,介绍1.1,得到的结果 2,参数类型2.1,字符串(不再推荐)2.2,对象2.3,函数函数调用时机 3,注意点 1,介绍 reference 引用。和 vue 中的 refs 类似&#x…

装机必备——360压缩安装教程

装机必备——360压缩安装教程 软件下载 软件名称:360压缩 软件语言:简体中文 软件大小:3.38M 系统要求:Windows7或更高, 32/64位操作系统 硬件要求:CPU2GHz ,RAM4G或更高 下载通道①迅雷云盘丨…

python自动化-自动化网络配置工具v2(可巡检,可批量配置)

在日常工作中遇到需要配置相同配置的场景,网络工程师一个个去登陆配置会让工作效率显得没那么高效。 但是随着科技发展,人们不断的学习,我们似乎可以使用一些软件或者脚本来帮助我们实现巡检任务或者配置任务。 今天我想给大家分享一款我自己…

PCIe协议之-DLLP详解

✨前言: 🌟数据链路层的功能 数据链路层将从物理层中获得报文, 并将其传递给事务层; 同时接收事务层的报文, 并将其转发到物理层; 核心的功能有以下三点 1.保证TLP在 PCIe 链路中的正确传递; 2.数据链路层使用了容错…

YOLOv10:实时端到端目标检测

Ao Wang Hui Chen∗  Lihao Liu Kai Chen Zijia Lin  Jungong Han Guiguang Ding Tsinghua University Corresponding Author. 文献来源:中英文对照阅读 摘要 在过去的几年里,YOLO 因其在计算成本和检测性能之间的有效平衡而成为实时目标检测领…

GitLab的安装及基础操作

1. 项目目标 (1)熟练使用rpm包安装gitlab (2)熟练配置gitlab (3)熟练创建gitlab群组、成员、项目 (4)熟练使用gitlab推送和拉取代码 2. 项目准备 2.1. 规划节点 主机名 主机I…

景源畅信电商:做抖音运营怎么开始第一步?

在数字化时代的浪潮中,抖音作为一款短视频平台迅速崛起,成为许多人表达自我、分享生活的重要舞台。随着用户量的激增,如何做好抖音运营,尤其是迈出成功的第一步,成为了众多内容创作者和品牌主们关注的焦点。接下来&…

鹏哥C语言复习——调试

目录 什么是调试? Debug和Release: 调试方法: 环境准备: 调试快捷键介绍: 调试快捷键注意事项: 监视与内存查看: 数组元素的监视: 编译常见错误归类: 编译型错…

基于SpringBoot的旅游管理系统

基于SpringBoot的旅游管理系统 旅游管理系统开发技术功能模块代码结构数据库设计运行截图源码获取 旅游管理系统 开发技术 技术:SpringBoot、MyBatis-Plus、MySQL、Beetl、Layui。 框架:基于开源框架Snowy-Layui开发。 工具:IDEA、Navicat等…

Linux文本文件管理003

★排序、去重、统计★ 1)排序 sort -n按照数值排序 -r降序排列 2)去重 uniq 过滤相邻、重复的行 -c 对重复行计数 3)统计 wc 统计文件中的字节数、单词数、行数 -l 显示行数 今天通过使用grep、awk、cut指令和上面几个选项提取文本文件…

三十一、openlayers官网示例Draw Features解析——在地图上自定义绘制点、线、多边形、圆形并获取图形数据

官网demo地址: Draw Features 先初始化地图,准备一个空的矢量图层,用于显示绘制的图形。 initLayers() {const raster new TileLayer({source: new XYZ({url: "https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/…

Pytorch 笔记

执行下面这段代码后,为什么返回的是 2 ? vector torch.tensor([7, 7]) vector.shape为什么返回的是 torch.Size([2])? 当你创建一个PyTorch张量时,它会记住张量中元素的数量和每个维度的大小。在你的代码中,torch.t…

软件程序设计规范(代码编写规范文档)-word下载

程序的编码是一个创造性极强的工作,必须要遵守一定的规则和限制,编码风格的重要性对软件项目开发来说是不言而喻的。 开发工程师在开发过程中必须遵守本规范,规范是代码编写及代码验收等管理环节中必须执行的标准。 编制基本原则:…

Java面试八股之volatile变量的作用

volatile变量的作用 内存可见性:volatile关键字最重要的作用是保证了变量的内存可见性。当一个线程修改了被volatile修饰的变量,这个修改会立即对其他线程可见,即使这些线程在不同的处理器上执行。这意味着volatile变量的更新不会被编译器优…

蓝桥杯—SysTick中断精准定时实现闪烁灯

在嵌入式系统中,SysTick_Handler 是一个中断服务例程(Interrupt Service Routine, ISR),用于处理 SysTick 定时器的中断。SysTick 定时器通常用于提供一个周期性的定时中断,可以用来实现延时或者周期性任务。 SysTick…

redis数据类型set,zset

华子目录 Set结构图相关命令sdiff key1 [key2]sdiffstore destination key1 [key2...]sinter key1 [key2...]sinterstore destination key1 [key2...]sunion key1 [key2...]sunionstore destination key1 [key2...]smove source destination memberspop key [count]sscan key c…