MySQL中的多表联查

--查询emp的id username age depName
create table emp(
id int unsigned auto_increment key,
username varchar(20) not null unique comment '编号',
age tinyint unsigned not null default 18 comment '年龄',
sex enum('男','女','保密') not null default '保密' comment '性别',
addr varchar(20) not null default '北京',
depId tinyint unsigned not null comment '部门对应的编号'
)engine=innodb charset=utf8; insert emp(username,age,depId) values('king',24,1),
('queen',25,2),
('imooc',26,1),
('lily',27,1),
('rose',28,3),
('john',29,3); create table dep(
id tinyint unsigned auto_increment key,
depName varchar(50) not null unique,
depDesc varchar(100) not null
)engine=innodb charset=utf8; insert dep(depName,depDesc) values('PHP教学部','研发PHP课件'),
('JAVA教学部','研发JAVA课件'),
('WEB教学部','研发WEB课件'),
('IOS教学部','研发IOS课件');

笛卡尔积的形式(不常用)

select emp.id,emp.username,emp.age,dep.depName from emp,dep;
--显示
+----+----------+-----+------------+
| id | username | age | depName |
+----+----------+-----+------------+
| 1 | king | 24 | IOS教学部 |
| 1 | king | 24 | JAVA教学部 |
| 1 | king | 24 | PHP教学部 |
| 1 | king | 24 | WEB教学部 |
| 2 | queen | 25 | IOS教学部 |
| 2 | queen | 25 | JAVA教学部 |
| 2 | queen | 25 | PHP教学部 |
| 2 | queen | 25 | WEB教学部 |
| 3 | imooc | 26 | IOS教学部 |
| 3 | imooc | 26 | JAVA教学部 |
| 3 | imooc | 26 | PHP教学部 |
| 3 | imooc | 26 | WEB教学部 |
| 4 | lily | 27 | IOS教学部 |
| 4 | lily | 27 | JAVA教学部 |
| 4 | lily | 27 | PHP教学部 |
| 4 | lily | 27 | WEB教学部 |
| 5 | rose | 28 | IOS教学部 |
| 5 | rose | 28 | JAVA教学部 |
| 5 | rose | 28 | PHP教学部 |
| 5 | rose | 28 | WEB教学部 |
| 6 | john | 29 | IOS教学部 |
| 6 | john | 29 | JAVA教学部 |
| 6 | john | 29 | PHP教学部 |
| 6 | john | 29 | WEB教学部 |
+----+----------+-----+------------+

内连接的形式(查询两个表中符合连接条件的记录)

--select 字段名称,... from tbl_name1 [inner] join tbl_name2 on 连接条件;
select e.id,e.username,e.age,d.depName
from emp as e
inner join dep as d
on e.depId=d.id;
--显示
+----+----------+-----+------------+
| id | username | age | depName |
+----+----------+-----+------------+
| 1 | king | 24 | PHP教学部 |
| 2 | queen | 25 | JAVA教学部 |
| 3 | imooc | 26 | PHP教学部 |
| 4 | lily | 27 | PHP教学部 |
| 5 | rose | 28 | WEB教学部 |
| 6 | john | 29 | WEB教学部 |
+----+----------+-----+------------+

外连接的形式

--左外连接(select 字段名称,... from tbl_name1 left [outer] join tbl_name2 on 条件;)
--先显示左表中的全部记录,再去右表中查询符合条件的记录,不符合的以null代替
select e.id,e.username,e.age,d.depName,d.depDesc
from emp as e
left outer join dep as d
on e.depId=d.id;
--显示
+----+----------+-----+------------+--------------+
| id | username | age | depName | depDesc |
+----+----------+-----+------------+--------------+
| 1 | king | 24 | PHP教学部 | 研发PHP课件 |
| 2 | queen | 25 | JAVA教学部 | 研发JAVA课件 |
| 3 | imooc | 26 | PHP教学部 | 研发PHP课件 |
| 4 | lily | 27 | PHP教学部 | 研发PHP课件 |
| 5 | rose | 28 | WEB教学部 | 研发WEB课件 |
| 6 | john | 29 | WEB教学部 | 研发WEB课件 |
+----+----------+-----+------------+--------------+ --右外连接(select 字段名称,... from tbl_name1 right [outer] join tbl_name2 on 条件;)
--先显示右表中的全部记录,再去左表中查询符合条件的记录,不符合的以null代替
select e.id,e.username,e.age,d.depName
from emp as e
right outer join dep as d
on e.depId=d.id;
--显示
+------+----------+------+------------+
| id | username | age | depName |
+------+----------+------+------------+
| 1 | king | 24 | PHP教学部 |
| 2 | queen | 25 | JAVA教学部 |
| 3 | imooc | 26 | PHP教学部 |
| 4 | lily | 27 | PHP教学部 |
| 5 | rose | 28 | WEB教学部 |
| 6 | john | 29 | WEB教学部 |
| NULL | NULL | NULL | IOS教学部 |
+------+----------+------+------------+

多表联查的操作

create table user(
id tinyint unsigned auto_increment key comment '编号',
username varchar(20) not null unique comment '用户名',
email varchar(50) not null default '2214@qq.com' comment '邮箱',
proId tinyint unsigned not null comment '用户所在省份的编号'
)engine=innodb charset=utf8; insert user(username,proId) values('a','1'),
('b','1'),
('c','1'),
('d','2'),
('e','3'),
('f','1'),
('g','1'); create table pro(
id tinyint unsigned auto_increment key comment '编号',
proName varchar(10) not null unique comment '省份名称'
)engine=innodb charset=utf8; insert pro(proName) values('北京'),('上海'),('深圳'); --查询user: id,username pro: proName
select u.id,u.username,p.proName
from user as u
join pro as p
on u.proId=p.id; --显示
+----+----------+---------+
| id | username | proName |
+----+----------+---------+
| 1 | a | 北京 |
| 2 | b | 北京 |
| 3 | c | 北京 |
| 4 | d | 上海 |
| 5 | e | 深圳 |
| 6 | f | 北京 |
| 7 | g | 北京 |
+----+----------+---------+ --修改北京为首都
update pro set proName='首都' where id=1;
--显示
+----+----------+---------+
| id | username | proName |
+----+----------+---------+
| 1 | a | 首都 |
| 2 | b | 首都 |
| 3 | c | 首都 |
| 4 | d | 上海 |
| 5 | e | 深圳 |
| 6 | f | 首都 |
| 7 | g | 首都 |
+----+----------+---------+

四个表关联的查询

create table pro2(
id tinyint unsigned not null auto_increment key comment '编号',
proName varchar(10) not null unique comment '省份名称'
)engine=innodb charset=utf8; insert pro2(proName) values('北京'),('上海'),('深圳'); create table admin(
id tinyint unsigned auto_increment key comment '编号',
username varchar(20) not null unique comment '用户名',
email varchar(50) not null default '24235@qq.com' comment '邮箱',
proId tinyint unsigned not null comment '用户所在省份的编号'
)engine=innodb charset=utf8; insert admin(username,proId) values('king',1),('queen',2); create table cate(
id tinyint unsigned auto_increment key comment '编号',
cateName varchar(50) unique comment '商品分类名称',
cateDesc varchar(100) not null default '好东西' comment '商品分类描述'
)engine=innodb charset=utf8; insert cate(cateName) values('母婴'),('服装'),('电子'); create table product(
id int unsigned auto_increment key comment '编号',
productName varchar(50) not null unique comment '商品名称',
price float(8,2) not null default '12' comment '价格',
cateId tinyint unsigned not null comment '商品所在分类的编号',
adminId tinyint unsigned not null comment '管理员编号'
)engine=innodb charset=utf8; insert product(productName,price,cateId,adminId) values('iphone9',9888,3,1),
('adidas',388,2,2),
('nike',888,2,2),
('奶瓶',288,1,1); --查询product:id productName price cate:catename(两个表)
select p.id,p.productName,p.price,c.cateName
from product as p
join cate as c
on p.cateId=c.id; --查询管理员 id username email pro:proName(两个表)
select a.id,a.username,a.email,p.proName
from admin as a
join pro2 as p
on a.proId=p.id; --查询product:id productName price
--cate:cateName
--admin:username email
--pro2:proName(四表查询)
select p.id,p.productName,p.price,c.cateName,a.username,a.email,pr.proName
from product as p
join admin as a
on p.adminId=a.id
join cate as c
on p.cateId=c.id
join pro2 as pr
on a.proId=pr.Id
where p.price<1000
order by p.price desc
limit 0,2;
--显示
+----+-------------+--------+----------+----------+--------------+---------+
| id | productName | price | cateName | username | email | proName |
+----+-------------+--------+----------+----------+--------------+---------+
| 3 | nike | 888.00 | 服装 | queen | 24235@qq.com | 上海 |
| 2 | adidas | 388.00 | 服装 | queen | 24235@qq.com | 上海 |
+----+-------------+--------+----------+----------+--------------+---------+

MySQL基础之数据管理【3】的更多相关文章

  1. MySQL基础之数据管理【4】

    外键约束的使用(只有InnoDB存储引擎支持外键) create table news_cate( id tinyint unsigned auto_increment key comment '编号 ...

  2. MySQL基础之数据管理【5】

    子查询的使用 select 字段名称 from tbl_name where col_name=(select col_name from tbl_name); --内层语句查询的结果可以作为外层语句 ...

  3. MySQL基础之数据管理【2】

    where条件筛选记录 select id,username,age from uesr where id=5; alter table user add userDesc varchar(100); ...

  4. MySQL基础之数据管理【1】

    添加记录 insert [into] tbl_name[(col_name,...)] {value|values}(values...); --不指定字段名称时需要按照建表时的字段顺序给每一个字段赋 ...

  5. MySQL基础----py全栈

    目录 MySQL基础----py全栈 一.引言 1.什么是数据? 2.什么是数据库(DB)? 3.什么是数据库管理系统(DBMS)? 4.什么是数据库系统? 5.数据库管理系统由来 6.什么是数据模型 ...

  6. Mysql基础代码(不断完善中)

    Mysql基础代码,不断完善中~ /* 启动MySQL */ net start mysql /* 连接与断开服务器 */ mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权限 ...

  7. MYSQL基础操作

    MYSQL基础操作 [TOC] 1.基本定义 1.1.关系型数据库系统 关系型数据库系统是建立在关系模型上的数据库系统 什么是关系模型呢? 1.数据结构可以规定,同类数据结构一致,就是一个二维的表格 ...

  8. 【夯实Mysql基础】记一次mysql语句的优化过程

    1. [事件起因] 今天在做项目的时候,发现提供给客户端的接口时间很慢,达到了2秒多,我第一时间,抓了接口,看了运行的sql,发现就是 2个sql慢,分别占了1秒多. 一个sql是 链接了5个表同时使 ...

  9. MySQL基础(非常全)

    MySQL基础 一.MySQL概述 1.什么是数据库 ? 答:数据的仓库,如:在ATM的示例中我们创建了一个 db 目录,称其为数据库 2.什么是 MySQL.Oracle.SQLite.Access ...

随机推荐

  1. docker安装mysql、es、jenkins等一些步骤以及如何设置docker国内镜像

    CentOS7安装Docker步骤: (0)删除旧的可能安装过的包 yum remove docker \                   docker-client \              ...

  2. flutter 打包apk

    打包的具体操作,可以参照官网,只是官网没有那么细 1.修改AndroidManifest.xml 2.构建配置  可以跳过 3.构建签名 4.创建 key.properties 5.配置混淆 6.修改 ...

  3. ABP入门教程15 - 小结

    点这里进入ABP入门教程目录 效果预览 至此,ABP入门教程的CURD(增删改查)示例已完成,效果如下 登录 首页 查询课程 新增课程 修改课程 删除课程 阶段总结 关键步骤: 领域层创建实体基础设施 ...

  4. 转战物联网·基础篇09-选择MQTT协议还是CoAP协议

      前面章节介绍过,MQTT协议和CoAP协议都是物联网中比较流行的协议,都对传输量做了很大的精简,传输开销小,以适应物理网的网络环境.   XMPP协议也有人说是适合物联网通信的,但它是基于XML, ...

  5. Saltstack_使用指南14_无master

    1. 主机规划 salt 版本 [root@salt100 ~]# salt --version salt (Oxygen) [root@salt100 ~]# salt-minion --versi ...

  6. linux 命令之touch

    转自:http://www.maomao365.com/?p=2037 一.touch命令简介touch的命令功能说明: 1 可以通过touch新建一个文件; 2 可以修改文件的时间戳; 3 可以批量 ...

  7. HashMap与HashTable的区别和理解

    Hashmap的理解 1:HashMap是基于哈希表的Map接口的非同步实现.此实现提供所有可选的映射操作,并允许使用null值和null键.HashMap储存的是键值对,HashMap很快.此类不保 ...

  8. C++ 数据类型判断 typeid

    #include <iostream> // typeid testing //////////////////////////////////////////////////////// ...

  9. LeetCode解题笔记 - 20. Valid Parentheses

    这星期听别人说在做LeetCode,让他分享一题来看看.试了感觉挺有意思,可以培养自己的思路,还能方便的查看优秀的解决方案.准备自己也开始. 解决方案通常有多种多样,我觉得把自己的解决思路记录下来,阶 ...

  10. 网络传播模型Python代码实现

    SI模型 import numpy as np import matplotlib.pyplot as plt import smallworld as sw #邻接矩阵 a = sw.a # 感染率 ...