**内连接查询(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
- );