MySQLUNION与UNIONALL语法与⽤法
1.MySQL UNION 语法violent
MySQL UNION ⽤于把来⾃多个语句的结果组合到⼀个结果集合中。语法为:
SELECT column,... FROM table1
UNION [ALL]
SELECT column,... FROM table2
...
在多个 SELECT 语句中,对应的列应该具有相同的,且第⼀个 SELECT 语句中被使⽤的字段名称也被⽤于结果的字段名称。
1.1.UNION 与 UNION ALL 的区别
当使⽤ UNION 时,MySQL 会把结果集中重复的记录删掉,⽽使⽤ UNION ALL ,MySQL 会把所有的记录返回,且效率⾼于 UNION。
2.MySQL UNION ⽤法实例
UNION 常⽤于数据类似的两张或多张表查询,如不同的数据分类表,或者是数据历史表等。下⾯是⽤于例⼦的两张原始数据表:article ⽂章表:
好看的画框图片aid title content
1⽂章
1⽂章1正⽂内容...
2⽂章
2⽂章2正⽂内容...
3⽂章
3⽂章3正⽂内容...
blog ⽇志表:
bid title content
1⽇志
1⽇志1正⽂内容...
2⽂章
2⽂章2正⽂内容...
3⽇志
3⽇志3正⽂内容...
上⾯两个表数据中,aid=2 的数据记录与 bid=2 的数据记录是⼀样的。
2.1.使⽤ UNION 查询
查询两张表中的⽂章 id 号及标题,并去掉重复记录:
SELECT aid,title FROM article UNION SELECT bid,title FROM blog
返回查询结果如下:
aid title
1⽂章1
2⽂章2
3⽂章3
1⽇志1
3⽇志3
2.2.UNION 查询结果说明
1. 重复记录是指查询中各个字段完全重复的记录,如上例,若 title ⼀样但 id 号不⼀样算作不同记录。
2. 第⼀个 SELECT 语句中被使⽤的字段名称也被⽤于结果的字段名称,如上例的 aid。企业网站建设综合实训心得体会
3. 各 SELECT 语句字段名称可以不同,但字段属性必须⼀致。
3.使⽤ UNION ALL 查询
查询两张表中的⽂章 id 号及标题,并返回所有记录:
SELECT aid,title FROM article UNION ALL SELECT bid,title FROM blog
3⽂章3
1⽇志1
2⽂章2
3⽇志3
显然,使⽤ UNION ALL 的时候,只是单纯的把各个查询组合到⼀起⽽不会去判断数据是否重复。因此,当确定查询结果中不会有重复数据或者不需要去掉重复数据的时候,应当使⽤ UNION ALL 以提⾼查询效率。
4.MySQL UNION ORDER BY
在 MySQL UNION 中使⽤和是有些需要特别注意的地⽅,因此单独列出来说明⼀下。
下⾯是⽤于例⼦测试的两张原始数据表:
article ⽂章表:
aid title content
1⽂章
1⽂章1正⽂内容...
2⽂章
2⽂章2正⽂内容...
3⽂章
3⽂章3正⽂内容...
blog ⽇志表:
bid title content
mysql语句分类1⽇志
1⽇志1正⽂内容...
2⽂章
2⽂章2正⽂内容...
3⽇志
3⽇志3正⽂内容...
4.1UNION ⼦句中使⽤ ORDER BY
⼦句中使⽤ ORDER BY,即将⼦句的结果先排序,然后再把这些⼦句查询的结果进⾏集合。
在⼦句中使⽤ ORDER BY,由于优先级问题,需要将整个⼦句加圆括号(),且必须与 LIMIT 结合使⽤:
(SELECT aid,title FROM article ORDER BY aid DESC LIMIT 10)
UNION ALL
(SELECT bid,title FROM blog ORDER BY bid DESC LIMIT 10)
返回查询结果如下:
aid title
3⽂章3
2⽂章2
delphi7中文企业版1⽂章1
3⽇志3
2⽂章2
1⽇志1
4.2UNION 整句中使⽤ ORDER BY
如果想使⽤ ORDER BY 或 LIMIT 来对全部 UNION 结果进⾏分类或限制,则应对单个 SELECT 语句加圆括号,并把 ORDER BY 或 LIMIT 放到最后⼀个的后⾯。
(SELECT aid,title FROM article)
UNION ALL
(SELECT bid,title FROM blog)
ORDER BY aid DESC
2⽂章2
2⽂章2
1⽂章1
1⽇志1
vector机器人整句中使⽤ ORDER BY,去掉 SELECT ⼦句中的圆括号虽然结果是⼀样的,但为了语句清晰,建议不要省略圆括号。
4.3 UNION ORDER BY 应⽤于别名
如果 SELECT 中使⽤到了,则 OEDER BY 必须引⽤别名:
(SELECT a AS b FROM table) UNION (SELECT ...) ORDER BY b
5.MySQL UNION LIMIT
在 MySQL UNION 中使⽤ LIMIT ⽤于限制返回的记录条数,如果对 SELECT ⼦句做限制,需要对 SELECT 添加圆括号:
(SELECT aid,title FROM article LIMIT 2)
UNION ALL
(SELECT bid,title FROM blog LIMIT 2)
该 SQL 会返回个 SELECT 语句的两条记录,如果不添加圆括号,则最后⼀个 LIMIT 2 会作⽤于整个 UNION 语句⽽⼀共返回 2 条记录。同 ORDER BY 类似,当需要对整个 UNION 的结果进⾏ LIMIT 限制时,建议将各个 SELECT 语句⽤圆括号括起来以使语句更加清晰:(SELECT aid,title FROM article)
UNION ALL
(SELECT bid,title FROM blog)
LIMIT 2
可见,LIMIT 与 ORDER BY 经常搭配使⽤,⼆者在 UNION 中的使⽤⽅式也是⼀致的。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论