数据库mysql入门基础--09.union的用法

.union的用法
1.union合并查询结果集
案例:查询工作岗位是MANAGER和SALESMAN的员工。
	select ename,job from emp where job = 'MANAGER' or job = 'SALESMAN';	
	select ename,job from emp where job in('MANAGER','SALESMAN');	
	| ename  |  job      |  
	| ALLEN  |  SALESMAN |
	| WARD   |  SALESMAN |
	| JONES  |  MANAGER  |
	| MARTIN |  SALESMAN |
	| BLAKE  |  MANAGER  |
	| CLARK  |  MANAGER  |
	| TURNER |  SALESMAN |

	select ename,job from emp where job = 'MANAGER'
	union
	select ename,job from emp where job = 'SALESMAN';
	| ename  |  job      |  
	| JONES  |  MANAGER  |
	| BLAKE  |  MANAGER  |
	| CLARK  |  MANAGER  |
	| ALLEN  |  SALESMAN |
	| WARD   |  SALESMAN |
	| MARTIN |  SALESMAN |
	| TURNER |  SALESMAN |
	union的效率要高一些,对于表连接来说,每连接一次新表,则匹配的次数满足笛卡尔积,成倍的翻。
	但是union可以减少匹配的次数,在减少匹配次数的情况下,还可以完成两个结果集的拼接:		
		a连接b连接c
		a:10条记录
		b:10条记录
		c:10条记录
		匹配次数是:1000
	
		a连接b一个结果:10 * 10 --> 100次
		a连接c一个结果:10 * 10 --> 100次
		使用union的话是:100+ 100= 200次。(union把乘法变成了加法,匹配的次数会减少)

2.union使用时的注意事项
	错误用法一:
		select ename,job from emp where job = 'MANAGER'
		union
		select ename from emp where job = 'SALESMAN';
		**原因:union在进行结果集合并的时候,要求两个结果集的列数相同。**

	错误用法二:
		select ename,job from emp where job = 'MANAGER'
		union
		select ename,sal from emp where job = 'SALESMAN';
		| ename  |  job      |  
		| JONES  |  MANAGER  |
		| BLAKE  |  MANAGER  |
		| CLARK  |  MANAGER  |
		| ALLEN  |  1600     |
		| WARD   |  1250     |
		| MARTIN |  1250     |
		| TURNER |  1500     |
		**原因:union结果集合并时列和列的数据类型也要相同,MYSQL不会报错,但是Oracle语法严格,会报错。**
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值