data:image/s3,"s3://crabby-images/195fc/195fc2572a31938bcc2209abfc10ef9e87a0e5b1" alt=""
每个部门的平均工资是不一样的;
--from子句中使用查询
分析:
1.首先要知道各个部门的平均工资
select avg(sal), deptno from emp group by deptno
data:image/s3,"s3://crabby-images/a8fb0/a8fb03b953a5de915fff9b0072c49b4647f51a66" alt=""
2.把上面的查询结果当做一个临时表对待
两张表,sal进行比较
data:image/s3,"s3://crabby-images/4b62b/4b62bd43fac32a64b8dd7d973c0201e40887bd19" alt=""
tem 临时表
tem表和emp表关联起来:
data:image/s3,"s3://crabby-images/c36d2/c36d2e2ed9b9e5b631696f609fdb2bd5e708b93b" alt=""
给所在部门的平均工资取别名 myavg
data:image/s3,"s3://crabby-images/4b0bf/4b0bf1b2532d569c95e3078dd7eec932e32e0e07" alt=""
data:image/s3,"s3://crabby-images/10aac/10aac99c9b5dde48aa4caf417bb131b7a5084454" alt=""
data:image/s3,"s3://crabby-images/ec6c1/ec6c1a27c71d85b62347c3ea576106664e0936e3" alt=""
不给子查询取别名,会访问不到需要的字段;
--top ID *
data:image/s3,"s3://crabby-images/25bed/25bed42fb45f790abea8109a91de77722064cdfc" alt=""
top 取5到10个
top 后面的数表示要取出几条记录;
top挑出6条,从emp表来,编号不能在xxx里面 not in
排除不要的4个人,排除前4个人;
data:image/s3,"s3://crabby-images/05460/05460f4831a90d03ec6943f859d55b7e7341fbec" alt=""
data:image/s3,"s3://crabby-images/1b165/1b1653a8d7a73b3d6ca2ab0eab393cb7cd272869" alt=""
data:image/s3,"s3://crabby-images/222b4/222b4ac224a8a882ec0667feef41e29a9810f56e" alt=""
data:image/s3,"s3://crabby-images/aa670/aa670f82865e8b8f256412404480c65a0103d64c" alt=""
top查询:
100万条记录,1-2秒钟可以出结果
identity(1, 1)表示该字段testID字段自增长,从1,每次+1
通过这条语句进行疯狂地复制,用于压力测试;
insert into test (testName, testpass)
select testName, testpass
from test;
比如用于邮件服务器的压力测试;
data:image/s3,"s3://crabby-images/a6c9e/a6c9ea4636fd93b12cddf503a8df6b8e58672a57" alt=""
字段越多,速度越慢;上百万的数据,分页查询,越到最后,速度越慢;
--如何删除一张表中的重复记录
data:image/s3,"s3://crabby-images/c37bb/c37bbd92fac80c37771c03130db0edd22fc97fec" alt=""
1.select distinct * into #temp3 from cat
2.delete from cat
3.insert into cat select * from #temp3
4.drop table #temp3
data:image/s3,"s3://crabby-images/2cf0b/2cf0b83ab7ab11c01fed566b17868c61a7942ab6" alt=""
1.把cat表的记录distinct后的结果放入到临时表#temp3中
2.把cat表的记录清空
3.把#temp表的数据(没有重复的记录),插入到cat表中 ;
4.删除临时表#temp3
--左外连接和右外连接
data:image/s3,"s3://crabby-images/cd398/cd398bc315edc966564d147316e31eef113ab104" alt=""
-要求没有上级的人名字也要显示出来null
left join 左外连
where换成on
data:image/s3,"s3://crabby-images/4aff9/4aff979f3c0a92f0697412ab569e44d00a2986f3" alt=""
select w.ename, b.ename
from emp w left join emp b on w.mgr=b.empno
左外连接:
指左边的表的记录全部显示,
如果 没有匹配的记录就用null填
emp w 表的记录全部出现;
data:image/s3,"s3://crabby-images/36802/36802b0bd04b5e71c556703d853cc9f1db3e2aaa" alt=""
--内连接:只有匹配上的才会出现
inner join xx on
data:image/s3,"s3://crabby-images/e908f/e908f09742a6398e97f440a62469d6080a086ce8" alt=""
--左外连接和右外连接
--思考题:显示公司每个员工和他的上级领导的名字
--内连接的处理方式(内连接只显示匹配的信息)
select worker.ename"员工名字",boss.ename"领导名字" from emp worker,emp boss where worker.mgr=boss.empno
--思考题:显示公司每个员工和他的上级领导的名字,没有上级领导的也要显示出来
--左外连接:指如果左边的表记录全部显示,如果没有匹配的记录,就用null填写
select worker.ename"员工名字",boss.ename"领导名字" from emp worker left join emp boss on worker.mgr=boss.empno
--右外连接:指如果右边的表记录全部显示,如果没有匹配的记录,就用null填写
select worker.ename"员工名字",boss.ename"领导名字" from emp worker right join emp boss on worker.mgr=boss.empno