首页 > 数据库技术 > 详细

MySQL查询(关联查询)

时间:2019-06-22 15:42:39      阅读:103      评论:0      收藏:0      [点我收藏+]

一、mysql查询与权限

(一)数据库关联查询

**内连接查询(inner join)**

查询两个表共有的数据,交集

技术分享图片

SELECT * FROM tb1 INNER JOIN tb2 ON 条件

 

所有有宿舍的学员

技术分享图片

 

左表查询(左关联查询)(left join)

查询两个表共有的数据,和左表所有的数据,左表有右表没有的部分用null代替

技术分享图片

 

SELECT * FROM tb1 LEFT JOIN tb2 ON 条件

 所有学员的住宿情况

 技术分享图片

 

右表查询(右关联查询)(right join)

查询两个表共有的数据,和右表表所有的数据,右表有左表没有的部分用null代替
技术分享图片

SELECT * FROM tb1 RIGHT JOIN tb2 ON 条件

 

 

所有宿舍的学员情况

技术分享图片


没有学员的宿舍
技术分享图片


没有宿舍的学员
技术分享图片

 

 

(二)多表(三表)关联查询

1、内关联查询
查看所有php的课程

技术分享图片

 

技术分享图片

 

技术分享图片

 

select * from major inner join major_course inner join course where 
major.id = major_course.major_id and major_course.course_id = course.id 
and major.id= 1;

 

 

技术分享图片

 

规范写法:

SELECT
m.id AS m_id,
m.name AS m_name,
c.id AS c_id,
c.name AS c_name
FROM
major AS m
INNER JOIN major_course AS mc
INNER JOIN course AS c
WHERE
m.id = mc.major_id
AND mc.course_id = c.id;

 



2、关联子查询
查询所有含有计算机基础的专业

SELECT
name
FROM
major
WHERE
id IN (
SELECT
mc.major_id
FROM
course AS c
LEFT JOIN major_course AS mc ON c.id = mc.course_id
WHERE
c.id = 1
);

 

技术分享图片

 

MySQL查询(关联查询)

原文:https://www.cnblogs.com/ilovepython/p/11068797.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!