SQL99之内连接查询

SQL99是SQL语言的一个标准,于1999年发布。内连接查询是SQL中非常常用的一种查询方式,用于根据指定的条件从两个或多个表中获取相关联的数据。下面将详细介绍SQL99中的内连接查询,并以通熟易懂的语言进行讲解,同时给出代码例子、注释及运行结果。

一、内连接查询概述

内连接(INNER JOIN)是一种基于两个或多个表共有列的等值条件的连接。它返回满足连接条件的记录,如果两个表中的记录在指定列上没有匹配的值,则不会出现在结果集中。 内连接查询的语法如下:

sql 复制代码
SELECT 列名1, 列名2, ...
FROM 表1
INNER JOIN 表2 ON 表1.列名 = 表2.列名;

二、代码例子及注释

假设有两个表:员工表(employee)和部门表(department),表结构及数据如下: 员工表(employee):

sql 复制代码
+----+------+--------+--------+
| id | name | dept_id | salary |
+----+------+--------+--------+
| 1  | 张三 | 1      | 8000   |
| 2  | 李四 | 2      | 9000   |
| 3  | 王五 | 1      | 10000  |
| 4  | 赵六 | 3      | 7000   |
+----+------+--------+--------+

部门表(department):

sql 复制代码
+----+----------+
| id | dept_name |
+----+----------+
| 1  | 研发部   |
| 2  | 市场部   |
| 3  | 财务部   |
+----+----------+
  1. 查询员工姓名、部门名称及薪资
sql 复制代码
SELECT e.name, d.dept_name, e.salary
FROM employee e
INNER JOIN department d ON e.dept_id = d.id;

注释:这里使用了表别名(e和d),方便在查询中引用表。通过INNER JOIN关键字将员工表和部门表进行内连接,连接条件为员工表的dept_id等于部门表的id。 运行结果:

sql 复制代码
+------+----------+--------+
| name | dept_name | salary |
+------+----------+--------+
| 张三 | 研发部   | 8000   |
| 李四 | 市场部   | 9000   |
| 王五 | 研发部   | 10000  |
| 赵六 | 财务部   | 7000   |
+------+----------+--------+
  1. 查询薪资大于8000的员工姓名、部门名称及薪资
sql 复制代码
SELECT e.name, d.dept_name, e.salary
FROM employee e
INNER JOIN department d ON e.dept_id = d.id
WHERE e.salary > 8000;

注释:在上一例子的基础上,添加了WHERE子句,用于筛选薪资大于8000的员工。 运行结果:

sql 复制代码
+------+----------+--------+
| name | dept_name | salary |
+------+----------+--------+
| 李四 | 市场部   | 9000   |
| 王五 | 研发部   | 10000  |
+------+----------+--------+
  1. 查询各部门员工数量、平均薪资及部门名称
sql 复制代码
SELECT d.dept_name, COUNT(e.id) AS employee_count, AVG(e.salary) AS avg_salary
FROM department d
INNER JOIN employee e ON d.id = e.dept_id
GROUP BY d.dept_name;

注释:这里使用了聚合函数COUNT和AVG,分别计算各部门的员工数量和平均薪资。通过GROUP BY子句按部门名称进行分组。 运行结果:

sql 复制代码
+----------+---------------+------------+
| dept_name | employee_count | avg_salary |
+----------+---------------+------------+
| 研发部   | 2             | 9000       |
| 市场部   | 1             | 9000       |
| 财务部   | 1             | 7000       |
+----------+---------------+------------+

三、总结

通过以上例子,我们可以看到内连接查询在SQL99中的使用方法。内连接查询能够有效地从多个表中获取相关联的数据,为数据分析提供便利。在实际应用中,我们可以根据需求灵活运用内连接查询,结合聚合函数、WHERE子句等,实现复杂的查询功能。需要注意的是,内连接查询只返回满足连接条件的记录,如果两个表中的记录在指定列上没有匹配的值,则不会出现在结果集中。在实际操作中,我们要根据业务需求选择合适的连接类型。

相关推荐
敖云岚2 小时前
【Redis】分布式锁的介绍与演进之路
数据库·redis·分布式
LUCIAZZZ3 小时前
HikariCP数据库连接池原理解析
java·jvm·数据库·spring·springboot·线程池·连接池
我在北京coding3 小时前
300道GaussDB(WMS)题目及答案。
数据库·gaussdb
小Tomkk3 小时前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
明月醉窗台4 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
沉到海底去吧Go5 小时前
【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案
数据库·qt·ocr·图片识别自动改名·图片区域识别改名·pdf识别改名
老纪的技术唠嗑局5 小时前
重剑无锋,大巧不工 —— OceanBase 中的 Nest Loop Join 使用技巧分享
数据库·sql
未来之窗软件服务6 小时前
JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟·东方仙盟数据库
一只爱撸猫的程序猿7 小时前
构建一个简单的智能文档问答系统实例
数据库·spring boot·aigc
nanzhuhe7 小时前
sql中group by使用场景
数据库·sql·数据挖掘