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. Implement Property Value Validation in the Application Model 在应用程序模型中实现属性值验证

    In this lesson, you will learn how to check whether or not a property value satisfies a particular r ...

  2. Vulnhub DC-1靶机渗透学习

    前言 之前听说过这个叫Vulnhub DC-1的靶机,所以想拿来玩玩学习,结果整个过程都是看着别人的writeup走下来的,学艺不精,不过这个过程也认识到,学会了很多东西. 所以才想写点东西,记录一下 ...

  3. OpenCV:图像的裁剪

    import cv2 import matplotlib.pyplot as plt def show(image): plt.imshow(image) plt.axis('off') plt.sh ...

  4. XPath匹配标签使用text()判断获取结果失败/为空的问题及解决方法

    XPath当匹配标签判断text()判断内容失败的问题及解决 问题复现 在爬取网站的时候我使用XPath去抓取网页上的内容,XPath表达式来精准获取需要的标签内容. 当我对如下一段html代码编写X ...

  5. 解决vue修改路由的查询字符串(query)url不改变,页面不刷新问题

    我个人猜测可能是对路由的数据检测深度不够吧,单纯修改query里面的属性是不能触发数据驱动的,因此要直接给query赋值新的对象才能驱动数据更新,做法如下 第一种 var query=JSON.par ...

  6. [Linux] 低版本centos升级git解决fatal: HTTP request failed

    编译用的一些依赖yum install curl-devel expat-devel gettext-devel openssl-devel zlib-develyum install gcc per ...

  7. RabbitMQ学习笔记(三、生产者与消费者)

    目录: 细说交换器 细说队列 发送消息 消费消息 确认与拒绝 细说交换器: 1.方法: public AMQP.Exchange.DeclareOk exchangeDeclare(String ex ...

  8. 201871010107-公海瑜《面向对象程序设计(java)》第一周学习总结

    201871010107-公海瑜<面向对象程序设计(java)>第一周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/   ...

  9. Tomcat中session复制技术

    一.准备三台机器主机的服务都正常,nginx与Tomcat构建负载均衡 主机名     IP地址 nginx       192.168.200.111 Tomcat1  192.168.200.11 ...

  10. 1+x 证书 Web 前端开发 css 专项练习

    官方QQ群 1+x 证书 Web 前端开发 css 专项练习 http://blog.zh66.club/index.php/archives/192/