MYSQL 寒假自学 2022 十一(二)

交叉连接查询

select * from dept3,emp3;

得到结果如下

还有很多,只截取了一部分。

内连接查询

实际上,内连接查询求的是两张表的交集。

-- 隐式内连接(SQL92标准):
select * from dept3,emp3 where dept3.deptno = emp3.dept_id;
-- 显示内连接(SQL99标准):
select * from dept3 inner join emp3 on dept3.deptno=emp3.dept_id; #其中 inner 可以省略

 

-- 隐式内连接(SQL92标准):
select * from dept3,emp3 where dept3.deptno = emp3.dept_id;
select * from dept3,emp3 where deptno = dept_id;
-- 显示内连接(SQL99标准):
select * from dept3 inner join emp3 on dept3.deptno=emp3.dept_id; #其中 inner 可以省略

-- 查询研发部门的所有成员
select * from dept3 inner join emp3 on dept3.deptno = emp3. dept_id&&name = '研发部';
-- 查看研发部和销售部的所有成员
select * from dept3 inner join emp3 on dept3.deptno = emp3. dept_id&&(name = '研发部'||name = '销售部');
select * from dept3 inner join emp3 on dept3.deptno = emp3. dept_id&&name in('研发部','销售部');

-- 查询每个部门的员工数,并升序排序
select dept3.deptno,dept3.name,count(1) from dept3 inner join emp3 on dept3.deptno=emp3.dept_id group by dept3.deptno,dept3.name order by count(1);

-- 查询人数大于等于三的部门,并按照人数降序排序
SELECT
	dept3.deptno,
	dept3.NAME,
	count( 1 ) 
FROM
	dept3
	INNER JOIN emp3 ON dept3.deptno = emp3.dept_id 
GROUP BY
	dept3.deptno,
	dept3.NAME 
HAVING
	count( 1 )>= 3 
ORDER BY
	count( 1 ) DESC; 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值