最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL入门之使用SQL99标准的连接查询

来源:懂视网 责编:小采 时间:2020-11-09 09:13:24
文档

MySQL入门之使用SQL99标准的连接查询

MySQL入门之使用SQL99标准的连接查询:使用SQL99标准的连接查询(JOIN..ON..) 内连接 只返回满足连接条件的数据(两边都有的才显示)。 select e. d. from emp e inner join dept d on e.deptno=d.deptno – 也可以省略inner关键字。 select e.*, d.* from emp
推荐度:
导读MySQL入门之使用SQL99标准的连接查询:使用SQL99标准的连接查询(JOIN..ON..) 内连接 只返回满足连接条件的数据(两边都有的才显示)。 select e. d. from emp e inner join dept d on e.deptno=d.deptno – 也可以省略inner关键字。 select e.*, d.* from emp

使用SQL99标准的连接查询(JOIN..ON..)

内连接 
只返回满足连接条件的数据(两边都有的才显示)。 
select e., d. 
from emp e 
inner join dept d 
on e.deptno=d.deptno 
– 也可以省略inner关键字。
select e.*, d.*
from emp e inner join dept d
on e.deptno=d.deptno

左外连接
 左边有值才显示。
 select e.*, d.*
 from emp e
 left outer join dept d
 on e.deptno=d.deptno
 -- 也可以省略outer关键字


右外连接
 右边边有值才显示。
 select e.*, d.*
 from emp e 
 right outer join dept d
 on e.deptno=d.deptno
 -- 也可以省略outer关键字

满外联接
 任一边有值就会显示。
 select e.*, d.*
 from emp e
 full outer join dept d 
 on e.deptno=d.deptno
 -- 也可以省略outer关键字

交叉连接:
 叉集,就是笛卡尔积
 select e.*, d.*
 from emp e
 cross join dept d
– 没有连接条件
eg:查询员工信息,员工号,姓名,月薪,部门名称 
select e.empno, e.ename, e.sal, d.dname 
from emp e, dept d 
where e.deptno=d.deptno
select e.empno, e.ename, e.sal, d.dname
from emp e inner join dept d -- 逗号join
on e.deptno=d.deptno -- where on
//显示所有部门信息 
//显示各个部门的部门人数 
select d.deptno 部门号, d.dname 部门名称,count(e.empno) 人数 
from emp e, dept d 
where e.deptno(+)=d.deptno 
group by d.deptno, d.dname
select d.deptno 部门号, d.dname 部门名称,count(e.empno) 人数
from emp e right outer join dept d
on e.deptno=d.deptno
group by d.deptno, d.dname
自连接: – 查询员工信息 ,老板信息 
显示: *的老板是* 
select e.ename , b.ename 
from emp e, emp b 
where e.mgr=b.empno
select concat ( concat(e.ename, ‘的老板是’), b.ename) 
from emp e, emp b 
where e.mgr=b.empno
select e.ename, ifnull(b.ename,’他自己’) 
from emp e left outer join emp b 
on e.mgr=b.empno
select concat ( concat(e.ename, ‘的老板是’), ifnull(b.ename,’他自己’)) 
from emp e left outer join emp b 
on e.mgr=b.empno 
+————————————————————————+ 
| concat ( concat(e.ename, ‘的老板是’), ifnull(b.ename,’他自己’)) | 
+————————————————————————+ 
| SMITH的老板是FORD | 
| ALLEN的老板是BLAKE | 
| WARD的老板是BLAKE | 
| JONES的老板是KING | 
| MARTIN的老板是BLAKE | 
| BLAKE的老板是KING | 
| CLARK的老板是KING | 
| SCOTT的老板是JONES | 
| KING的老板是他自己 | 
| TURNER的老板是BLAKE | 
| ADAMS的老板是SCOTT | 
| JAMES的老板是BLAKE | 
| FORD的老板是JONES | 
| MILLER的老板是CLARK | 
+————————————————————————+

文档

MySQL入门之使用SQL99标准的连接查询

MySQL入门之使用SQL99标准的连接查询:使用SQL99标准的连接查询(JOIN..ON..) 内连接 只返回满足连接条件的数据(两边都有的才显示)。 select e. d. from emp e inner join dept d on e.deptno=d.deptno – 也可以省略inner关键字。 select e.*, d.* from emp
推荐度:
标签: 查询 连接 初学者
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top