目录
1.内连接查询
1.1:隐式内连接:使用where条件消除无用的数据
1.2:内连接的思维逻辑:从哪些表中查询数据,条件是什么,查询哪些字段
图形化界面中输写mysql语句正确格式:
SELCET
t.name,
t.age
t1.name
FROM
emp t,
dept t1,
WHERE
t.'dept_id = t1.'id';
2.显式内连接
2.1 内连接:inner join
2.2 语法: select 字段列表 from 表名列表 inner join 表名 on 条件
2.3:inner 是可选,可用可不用的
3.外连接查询
3.1:左外连接
3.2:语法 select 字段列表 from 表1 left outer join 表2 on 条件;
3.3查询的是左表所有数据以及交集部分
3.4:注意 outer 可有可无
3.5: 右外连接
3.6 语法: select 字段列表 from 表1 right outer join 表2 on 条件;
3.7查询的是右表所有数据以及交集部分
4 子查询
4.1 查询中嵌套查询,称嵌套查询为子查询
4.2 子查询的结果是单行单列的,
4.3 理解使用运算符来判断 运算符: > >= < <= =
4.4案例
查询员工工资小于平均工资的人
select * from emp where emp.salary < (select avg(salary) from emp);
4.5 子查询的结果是多行单列的
4.6 理解:子查询可以作为条件,使用运算符in 来判断
4.7 查询 财务部和市场部 所有的员工信息
select * from emp where dept_id in (select id from dept where name = '财务部' or name = ' 市场部');
5.0 子查询的结果是多行多列的
5.1 理解:子查询可以作为一张虚拟表参与查询
5.2 案例: 查询学生name为20之后的 学生信息和课程信息
5.3 select * from student a1,(select * from cour where cour.name > 20) a2 where a1.id = a2.id;
笛卡尔积:有两个集合a.b 取这两个集合的所有组成情况
注意:要完成多表查询,需要消除无用的数据