关于MySQL92和99 等值连接、非等值连接、自连接、外连接及多表查询的代码示例总结!

关于MySQL92和99 等值连接、非等值连接、自连接、外连接及多表查询的代码示例总结!

一. MySQL92语法

*1. 内连接 没有关联关系的数据是不在查询范围之内的
*
1)等值连接

– 查询出101的班级信息(并带上该班级的所有学生信息)

SELECT *FROM class,student 
        WHERE class.`id`=student.`clazz_id` 
        AND class.`name`='101';

– 查询出rose的所有信息(包括班级信息)

SELECT *FROM class,student 
        WHERE class.`id`=student.`clazz_id`
        AND student.`name`='rose'; 

2)三表查询(多对多)

– 查询出rose的个人信息(包括其选修课程信息)

SELECT *FROM student,course,course_student 
        WHERE student.`id`=course_student.`stu_id`
        AND course.`id`=course_student.`cou_id`
        AND student.`name`='rose';

– 查询出java这门课的信息(包括选该门课的学生)

SELECT * FROM student,course,course_student
        WHERE student.`id`=course_student.`stu_id`
        AND course.`id`=course_student.`cou_id`
        AND course.`name`='hadoop';

3)一对一

– 查询出孙俪的个人信息(包括其丈夫的信息)

SELECT * FROM husband,wife 
         WHERE wife.`wife_id`=husband.`wife_id` 
         AND wife.`wife_name`='孙俪';

– 查询出所有班级的信息(包括其学生的信息)

SELECT * FROM class,student 
         WHERE class.`id`=student.`clazz_id`;

4)非等值连接

扫描二维码关注公众号,回复: 12120526 查看本文章

– 查询出所有学生的信息(包括他的年龄级别)

SELECT *FROM student,age_tb 
        WHERE student.`age`>=age_tb.`min`
        AND student.`age`<age_tb.`max`;

5)自连接

– 查询出北京市的信息(包括其区的信息)

SELECT *FROM city c1,city c2 
        WHERE c1.`id` =c2.`parent_id`
        AND c1.`name`='北京市';

2.外连接(不支持)

二. MySQL99语法

1.内连接
1)等值连接(对比)

 -- 查询出101的班级信息(并带上该班级的所有学生信息)
SELECT *FROM class,student 
        WHERE class.`id`=student.`clazz_id` 
        AND class.`name`='101';
        
SELECT *FROM class I
       NNER JOIN student 
       ON class.`id`=student.`clazz_id` 
       WHERE class.`name`='101'
       
-- 查询出rose的所有信息(包括班级信息)
SELECT *FROM class,student 
        WHERE class.`id`=student.`clazz_id`
        AND student.`name`='rose'; 
        
SELECT *FROM class 
        INNER JOIN student ON class.`id`=student.`clazz_id`WHERE student.`name`='rose'

2)非等值连接

-- 查询出所有学生的信息(包括他的年龄级别)
SELECT *FROM student,age_tb 
        WHERE student.`age`>=age_tb.`min`
        AND student.`age`<age_tb.`max`;
        
SELECT *FROM student 
        INNER JOIN age_tb 
        ON student.`age`>=age_tb.`min`
        AND student.`age`<age_tb.`max`;

3)自连接

-- 查询出北京市的信息(包括其区的信息)
SELECT *FROM city c1,city c2 
        WHERE c1.`id` =c2.`parent_id`
        AND c1.`name`='北京市';
        
SELECT *FROM city c1 
        INNER JOIN city c2 
        ON  c1.`id` =c2.`parent_id`
        AND c1.`name`='北京市';

4)三表连接

-- 查询出rose的个人信息(包括其选修课程信息)
SELECT *FROM student,course,course_student 
        WHERE student.`id`=course_student.`stu_id`
        AND course.`id`=course_student.`cou_id`
        AND student.`name`='rose';
        
SELECT *FROM student 
        INNER JOIN course 
        JOIN course_student
        ON student.`id`=course_student.`stu_id`
        AND course.`id`=course_student.`cou_id`
        WHERE student.`name`='rose'

5)一对一

-- 查询出孙俪的个人信息(包括其丈夫的信息)
SELECT * FROM husband,wife 
         WHERE wife.`wife_id`=husband.`wife_id` 
         AND wife.`wife_name`='孙俪';
         
SELECT *FROM husband INNER JOIN wife
        ON wife.`wife_id`=husband.`wife_id` 
        WHERE wife.`wife_name`='孙俪'
-- 查询出所有班级的信息(包括其学生的信息)
SELECT * FROM class,student 
         WHERE class.`id`=student.`clazz_id`;
         
SELECT *FROM class 
         INNER JOIN student 
         ON class.`id`=student.`clazz_id`;

2.外连接
1)左外连接

-- 查询出所有班级的信息(包括其学生的信息)
SELECT *FROM class
        LEFT JOIN student 
        ON class.`id`=student.`clazz_id`;
        
-- 查询出所有学生的信息(包括其班级的信息)
SELECT *FROM student 
        LEFT JOIN class 
        ON class.`id`=student.`clazz_id`;

2)右外连接

-- 查询出所有学生的信息(包括其班级的信息)
SELECT *FROM class 
        RIGHT JOIN student 
        ON class.`id`=student.`clazz_id`;
-- 查询出所有班级的信息(包括其学生的信息)
SELECT *FROM student 
        RIGHT JOIN class 
        ON class.`id`=student.`clazz_id`;

3)全外连接(sql不支持)
左外和右外拼接

-- 查询学生和班级的所有数据
SELECT *FROM class 
        LEFT JOIN student 
        ON class.`id`=student.`clazz_id`  #(结尾处不要写分号)
UNION
SELECT *FROM class 
        RIGHT JOIN student 
        ON class.`id`=student.`clazz_id`;

猜你喜欢

转载自blog.csdn.net/qq_43597431/article/details/111499870
今日推荐