SQL99版链接查询语法

连接查询按照功能分类

内连接

等值连接

非等值连接

自连接 //92SQL

外连接: //红色的连接查询类型92版SQL

左外连接

右外连接

全外连接

交叉连接

#剩下连接类型的SQL语法就不是前面同一个发布版本了

99版SQL语法格式区别于92版的是连接不在是用"="了,它是语法格式:

sql 复制代码
select 查询列表
from 表1 别名
【链接类型】 join 表2 别名
on 链接条件
where 数据筛选条件 .....以前讲过的其他部分;

【链接类型】的关键字

内连接:inner (还可以省略)

外连接:

左外连接 left 【outer】

右外连接 right 【outer】

全外连接 full 【outer】

交叉连接 cross 【outer】

案例1:用99版的SQL写法实现等值连接查询

1.查询员工名和其对应所属的部门名

sql 复制代码
select last_name,department_name
from employees e
inner join departments d
on e.department_id = d.department_id;

2.查询名字中包含e字母的员工名和其对象的部门名

sql 复制代码
select last_name , department_name
from employees e
inner join departments d
on e.department_id = d.department_id
where last_name like '%e%';

3.查询所在部门个数大于3的城市名和部门个数

sql 复制代码
select count(d.department_id) count , l.city
from departments d
inner join locations l
on d.location_id = l.location_id
group by l.city
having count>3;

4.查询员工个数大于3点部门名和员工个数,降序排序

sql 复制代码
SELECT d.department_name , COUNT(e.employee_id) c
FROM employees e
INNER JOIN departments d
ON e.department_id=d.department_id
GROUP BY d.department_name
HAVING c>3
ORDER BY c DESC;

5.查询员工名以及对应的工种名和部门名,按部门名降序排序

sql 复制代码
select e.last_name,j.job_title,d.department_name
from employees e
inner join departments d
on e.department_id = d.department_id
inner join jobs j
on e.job_id=j.job_id
order by d.department_name;

案例2:用99版的SQL写法实现非等值连接查询

sql 复制代码
SELECT
salary,grade_level
FROM
employees e
INNER JOIN
job_grades g
ON
e.salary BETWEEN g.`lowest_sal` AND g.`highest_sal`;

练习

查询同一个工资级别的员工的个数大于20的员工个数,并且按照工资级别降序排序

sql 复制代码
SELECT
COUNT(*) 员工个数,`grade_level`
FROM
`employees` e
INNER JOIN
`job_grades` g
ON
e.`salary` BETWEEN g.`lowest_sal` AND g.`highest_sal`
GROUP BY
`grade_level`
HAVING
COUNT(*)>20
ORDER BY
`grade_level` DESC;

案例3:用99版的SQL写法实现自连接查询

查询员工的名和其对应的直属领导

sql 复制代码
SELECT
e.last_name employee_name,
m.last_name manager_name
FROM
employees e
INNER JOIN
employees m
ON
e.`manager_id`=m.`employee_id`;
相关推荐
AC赳赳老秦22 分钟前
DeepSeek教育科技应用:智能生成个性化学习规划与知识点拆解教程
前端·网络·数据库·人工智能·学习·matplotlib·deepseek
枫叶丹41 小时前
【Qt开发】Qt系统(一)-> 定时器 QTimerEvent 和 QTimer
c语言·开发语言·数据库·c++·qt·系统架构
计算机毕设VX:Fegn08955 小时前
计算机毕业设计|基于springboot + vue在线考试系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
ejjdhdjdjdjdjjsl8 小时前
JSON序列化与反序列化实战指南
数据库·microsoft·c#
CC.GG8 小时前
【C++】STL容器----unordered_map和unordered_set的使用
java·数据库·c++
编程小Y9 小时前
如何优化MySQL的查询性能?
数据库·mysql
用户47949283569159 小时前
性能提升 40 倍!实战 PostgreSQL FDW 解决微服务跨库查询难题
数据库·后端
计算机毕设VX:Fegn089510 小时前
计算机毕业设计|基于springboot + vue宠物医院管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
贺今宵10 小时前
安装better-sqlite3报错electron-vite
javascript·sql·sqlite·sqlite3
kimi-22210 小时前
LangChain 将数据加载到 Chroma 向量数据库
数据库·langchain