数据库MySQL--连接查询
例子文件1:https://files.cnblogs.com/files/Vera-y/myemployees.zip
例子文件2:https://files-cdn.cnblogs.com/files/Vera-y/girls.zip
连接查询:又称多表查询,当查询的字段来自多个表时,将会运用到连接查询
连接查询的分类:
1.按年代分类:
sql92标准:92年推出的标准,仅仅支持内连接
语法: select 查询列表
from 表
where 连接条件、(筛选条件)
(group by 分组)
(having 筛选条件)
(order by 排序列表)
sql99标准:99年推出的标准,MySQL中99标准支持内连接,外连接(全外连接不支持),交叉连接
语法: select 查询列表
from 表1 (连接类型)
join 表2
on 连接条件
(where筛选条件)
(group by 分组)
(having 筛选条件)
(order by 排序列表)
2.按功能分类:
内连接:等值连接,非等值连接,自连接
外连接:左外连接,右外连接,全外连接
交叉连接
spl99 标准功能分类连接类型:
内连接:inner (可以省略)
外连接:左外:left (outer)、右外:right(outer)、全外:full(outer)
交叉连接:cross
壹:内连接
一、等值连接
1.简单基础的等值查询
例1.查询员工名和对应的部门名
sql92:
SELECT last_name,department_name
FROM employees,departments
WHERE employees.department_id = departments.department_id;
# 注意两个表是通过什么连接的,这里是通过department_id连接的(又称键)
sql99:
SELECT last_name,department_name
FROM employees INNER JOIN departments
ON employees.department_id = departments.department_id;
例2.查询员工名、工种号、工种名
SELECT last_name,employees.job_id,job_title
FROM employees,jobs # 在这里可以给表起别名
WHERE employees.job_id = jobs.job_id;
(注:虽然可以起别名,但是一旦起了别名,使用到表名的地方就一定要用别名代替,否则报错)
2. 加筛选条件的等值查询
例1.查询有奖金的员工名、部门名
sql92:
SELECT last_name, department_name
FROM employees,departments
WHERE commission_pct IS NOT NULL
AND employees.department_id=departments.department_id;
sql99:
SELECT last_name,department_name
FROM employees INNER JOIN departments
ON employees.department_id=departments.department_id
WHERE commission_pct IS NOT NULL;
例2.查询城市名中第二个字符为o的部门名和城市名
SELECT department_name,city
FROM departments,locations
WHERE departments.location_id=locations.location_id
AND city LIKE '_o%';
3.添加分组
例1.查询每个城市的部门个数
sql92:
SELECT COUNT(*),city
FROM departments,locations
WHERE departments.location_id=locations.location_id
GROUP BY city;
sql99:
SELECT COUNT(*),city
FROM departments INNER JOIN locations
ON departments.location_id=locations.location_id
GROUP BY city;
例2.查询有奖金的每个部门的部门名和部门的领导编号和该部门的最低工资
SELECT department_name,MIN(salary),departments.manager_id
FROM departments,employees
WHERE departments.department_id=employees.department_id
AND commission_pct IS NOT NULL
GROUP BY department_name,departments.manager_id;
可能出现的一个错误:https://www.cnblogs.com/Vera-y/p/10923850.html
3.添加排序
例1:查询每个工种的工种名和员工的个数,并且按员工个数排降序
SELECT job_title,COUNT(*)
FROM jobs, employees
WHERE jobs.job_id=employees.job_id
GROUP BY job_title
ORDER BY COUNT(*) DESC;
例2.查询那个部门的员工个数>3的部门名和员工个数,并按个数降序
sql92:
SELECT department_name,COUNT(*)
FROM departments,employees
WHERE departments.department_id=employees.department_id
GROUP BY department_name
HAVING COUNT(*)>3
ORDER BY COUNT(*) DESC;
sql99:
SELECT department_name,COUNT(*)
FROM departments INNER JOIN employees
ON departments.department_id=employees.department_id
GROUP BY department_name
HAVING COUNT(*)>3
ORDER BY COUNT(*) DESC;
4.三表连接
例:查询员工名、部门名、和所在城市
sql92:
SELECT last_name,department_name,city
FROM employees,departments,locations
WHERE employees.department_id=departments.department_id
AND departments.location_id=locations.location_id;
sql99:
SELECT last_name,department_name,city
FROM employees
INNER JOIN departments ON employees.department_id=departments.department_id
INNER JOIN locations ON departments.location_id=locations.location_id;
(注:顺序问题:两个表一定要有连接条件才能让两个表相连)
二、非等值连接
案例:查询员工的工资和工资级别
sql92:
SELECT salary,grade_level
FROM employees,job_grades
WHERE salary BETWEEN job_grades.lowest_sal AND job_grades.highest_sal; # 这里用between and 限制了范围
sql99:
SELECT salary,grade_level
FROM employees
JOIN job_grades # 省略了inner
ON employees.salary BETWEEN job_grades.lowest_sal AND job_grades.highest_sal;
三、自连接
自个儿的表和自个儿的表连接
案例:查询姓名中包含k的员工名和上级领导的名称
sql92:
SELECT e.employee_id, e.last_name,m.employee_id,m.last_name
FROM employees AS e,employees AS m # 这里的别名用作区分为两个表
WHERE e.manager_id=m.manager_id
AND e.last_name LIKE '%k%';
sql99:
SELECT e.employee_id, e.last_name,m.employee_id,m.last_name
FROM employees AS e
JOIN employees AS m # 这里省略了inner
ON e.manager_id=m.manager_id
WHERE e.last_name LIKE '%k%';
贰:外连接
(sql99标准的外连接)
1、外连接:一个表中有,另一个表中没有的
外连接的查询结果为主表中的所有记录
若从表中有和主表匹配的,则显示匹配值
若从表中没有和主表匹配的,则用null填充
即:外连接结果=内连接结果+主表中有而从表中没有的记录
2、左外连接:left join 左边的是主表
右外连接:right join 右边的是主表
左外和右外交换两个表的顺序可以实现同样的效果
3、全外连接=内连接的结果+表1中有但表2中没有+表2中有表1中没有
4、交叉连接:笛卡尔乘积
例1.查询男朋友不在男神表的女神名 # 最终查询的为女神名来自与女神表,所以主表为女神表
左外连接:
SELECT beauty.`name`,beauty.*
FROM beauty
LEFT OUTER JOIN boys
ON beauty.boyfriend_id=boys.id
WHERE boys.id IS NULL; # 主键是不可能本身就为空的,所以只能是匹配后为空
右外连接:
SELECT beauty.`name`,beauty.*
FROM boys
RIGHT OUTER JOIN beauty
ON beauty.boyfriend_id=boys.id
WHERE boys.id IS NULL;
例2.查询那个部门没有员工 # 最终查询的是部门的,所以部门表为主表
左外连接:
SELECT departments.*, employees.employee_id
FROM departments
LEFT JOIN employees
ON employees.department_id = departments.department_id
WHERE employees.department_id IS NULL;
右外连接:
SELECT departments.*, employees.employee_id
FROM employees
RIGHT JOIN departments
ON employees.department_id = departments.department_id
WHERE employees.department_id IS NULL;
例3.查询部门名为SAL 或IT的员工信息
SELECT departments.department_name,employees.*
FROM departments
LEFT JOIN employees
ON departments.department_id = employees.department_id
WHERE departments.department_name IN('SAL','IT');
例4、交叉连接
SELECT beauty.*,boys.*
FROM beauty
CROSS JOIN boys;
有关几个查询的小统计:
数据库MySQL--连接查询的更多相关文章
- MySql数据库之连接查询
在MySql数据库中连接查询分为以下几种方式: 1.内连接查询 内连接查询通过关键字 inner join 关键字来实现,通过代码实现: select * from 表1 inner join 表2 ...
- mysql连接查询经典小例题
mysql连接查询: Mysql连接查询支持多表连接 对同一张表可以重复连接多次(别名在多次连接同一张表时很重要) 例题1: 下面有2张表 teams表 比赛结果表:result 问题: 得出一张表: ...
- MySQL连接查询、联合查询、子查询
参考地址:http://blog.csdn.net/u011277123/article/details/54863371 1.MySQL连接查询 连接查询:将多张表(>=2)进行记录的连接(按 ...
- 掌握MySQL连接查询到底什么是驱动表
准备我们需要的表结构和数据 两张表 studnet(学生)表和score(成绩)表, 创建表的SQL语句如下 CREATE TABLE `student` ( `id` int(11) NOT NUL ...
- MySQL连接查询驱动表被驱动表以及性能优化
准备我们需要的表结构和数据 两张表 studnet(学生)表和score(成绩)表, 创建表的SQL语句如下 CREATE TABLE `student` ( `id` int(11) NOT NUL ...
- 细说MySQL连接查询:内连、左连和右连
转: 细说MySQL连接查询:内连.左连和右连 简介: MySQL 的连接查询,通常都是将来自两个或多个表的行结合起来,基于这些表之间的共同字段,进行数据的拼接.首先,要确定一个主表作为结果集,然后将 ...
- SQLServer数据库之连接查询
SQLServer数据库之连接查询 表的连接查询的几种方法介绍: inner join on内连接,left join on 左连接 , rigth join on 右连接, full join on ...
- mysql连接查询,封装mysql函数
连接查询 交叉连接语法: select * | 字段列表 from 表1 cross join 表2 内连接: select *|字段列表 from 左表 inner join 右表 on 左表. ...
- Mysql连接查询、子查询、联合查询 整理
连接查询 连接语法的基本形式 from 表1 [连接方式] join 表2 [on 连接条件]: 交叉连接 语法: from 表1 [cross] join 表2 ; //可 ...
- MySQL连接查询(inner join,left join和right join的区别)
关系数据库由多个相关表组成,这些表使用已知为外键列的常用列链接在一起. 因此,从业务角度来看,每个表中的数据是不完整的. 例如,在示例数据库(yiibaidb)中,使用orderNumber列链接的o ...
随机推荐
- Samcompu Loves Water
题目背景 Samcompu拥有大量的"水"资源!! 题目描述 Samcompu需要制定一个水计划.这个计划的主要目的就是为了避开老师监视的时间来水. 老师在中途会离开机房T次,第i ...
- utmp, wtmp - 登 录 记 录(login records)
SYNOPSIS[总览] #include DESCRIPTION[描述] utmp 文 件 用 于 记 录 当 前 系 统 用 户 是 哪 些 人. 但 是 实 际 的 人 数 可 能 比 这 个 ...
- mysql的sql筛选排重最大值并修改其属性
修改属性 mysql -h192.168.1.51 -uroot -e "use codex_game_s1051_h; update user_info set isActive=0 wh ...
- JS window对象 计时器setTimeout() setTimeout()计时器,在载入后延迟指定时间后,去执行一次表达式,仅执行一次。 语法: setTimeout(代码,延迟时间);
计时器setTimeout() setTimeout()计时器,在载入后延迟指定时间后,去执行一次表达式,仅执行一次. 语法: setTimeout(代码,延迟时间); 参数说明: 1. 要调用的函数 ...
- C++11 auto 与 右值
auto: auto T = xxx; // 产生一个变量,自动推导变量类型. 存在变量拷贝的消耗.auto& T = xxx; // 产生一个变量的引用,自动推导变量类型.减少拷贝的消耗. ...
- Python全栈开发:RabbitMQ/Redis/Memcache/SQLAlchemy
Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...
- java 面试2019
[第一部分] 面试要领[第1题] 流程必知必会[第2题] JDK源码[第二部分] 类和对象[第二篇] 面向对象基础[第1题] 面向对象是什么?[第2题] 类加载的过程[第3题] 类加载器有哪些[第4题 ...
- C#/.NET 实现的多屏联动,多屏共享,显示到指定屏幕上
假设我现在有4个屏幕,希望实现主屏幕在操作的时候,其他3块屏幕可以实时联动,并且延迟在1s以内. 正常情况下,我们可以借助于各个远程软件实现效果,但是有时候会显得笨重麻烦,假如只有一台服务器呢?? S ...
- Razor页面之添加TagHelper
1.右键项目-----添加------新建项 2.创建Razor试图导入 (Razor View Imports) 3.在创建的_ViewImports.cshtml中添加 @AddTagHelpe ...
- vue中数据绑定遇到的问题
<!-- 使用element中的表格组件,在编辑的时候传递每行的数据 --> <el-button size="small" type="success ...