MySQLunion 语法代码演示

数据库 MySQL
我们今天主要向大家介绍的是MySQLunion 语法代码演示,如果你对其相关的实际操作有兴趣的话,以下就是相关内容的具体描述。

以下的文章主要介绍的是MySQLunion 语法代码演示,我前两天在相关网站看见MySQLunion 语法代码演示的资料,觉得挺好,就拿出来供大家分享。希望在你今后的学习中会对你有所帮助。

复制代码

  1. SELECT ...   
  2. UNION [ALL | DISTINCT]   
  3. SELECT ...   
  4. [UNION [ALL | DISTINCT]   
  5. SELECT ...]   
  6. SELECT ... UNION [ALL | DISTINCT] SELECT ... [UNION [ALL | DISTINCT] SELECT ...]  

UNION 用于把来自许多SELECT语句的结果组合到一个结果集合中。 (如果你要将多个表的查询结果进行合并输出比如说 群组消息跟个人消息表是分离的但是想一起提取出来并显示的话就可以如此处理。通过MySQLUNION联合查询出来即可)

列于每个SELECT语句的对应位置的被选择的列应具有相同的类型(前提条件是两个SELECT出来的列类型要保持一样的才行!)。(例如,被*** 个语句选择的***列应和被其它语句选择的***列具有相同的类型。)在***个SELECT语句中被使用的列名称也被用于结果的列名称。

SELECT语句为常规的选择语句,但是受到如下的限定:

只有***一个SELECT语句可以使用INTO OUTFILE。

HIGH_PRIORITY不能与作为UNION一部分的SELECT语句同时使用。如果您对***个 SELECT指定了HIGH_PRIORITY,则不会起作用。如果您对其它后续的SELECT语句指定HIGH_PRIORITY,则会产生语法错 误。

如果您对UNION不使用关键词ALL,则所有返回的行都是唯一的,如同您已经对整个结果集合使用了DISTINCT。如果您指定了ALL,您会从 所有用过的SELECT语句中得到所有匹配的行。

DISTINCT关键词是一个自选词,不起任何作用,但是根据SQL标准的要求,在语法中允许采用。(在MySQL中,DISTINCT代表一个共 用体的默认工作性质。)

您可以在同一查询中混合UNION ALL和UNION DISTINCT。被混合的UNION类型按照这样的方式对待,即DISTICT共用体覆盖位于其左边的所有ALL共用体。DISTINCT共用体可以使 用UNION DISTINCT明确地生成,或使用UNION(后面不加DISTINCT或ALL关键词)隐含地生成。

如果您想使用ORDER BY或LIMIT子句来对全部UNION结果进行分类或限制,则应对单个地SELECT语句加圆括号,并把ORDER BY或LIMIT放到***一个的后面。以下例子同时使用了这两个子句:

代码 复制代码

  1. (SELECT a FROM tbl_name WHERE a=10 AND B=1)UNION(SELECT a FROM tbl_name WHERE a=11 AND B=2)ORDER BY a LIMIT 10;  

(如果想要实现分页的话可以这样处理 将两个查询的结果集当作是一个大的结果集处理然后再对此大的结果集进行LIMIT处理即可实现!)好好好 ~!
(SELECT a FROM tbl_name WHERE a=10 AND B=1)MySQLUNION(SELECT a FROM tbl_name WHERE a=11 AND B=2)ORDER BY a LIMIT 10;

这种ORDER BY不能使用包括表名称(也就是,采用tbl_name.col_name格式的名称)列引用。可以在***个SELECT语句中提供一个列别名,并在 ORDER BY中参阅别名,或使用列位置在ORDER BY中参阅列。(***采用别名,因为不建议使用列位置。)

另外,如果带分类的一列有别名,则ORDER BY子句必须引用别名,而不能引用列名称。以下语句中的***个语句必须运行,但是第二个会运行失败,出现在'order clause'中有未知列'a'的错误:

代码 复制代码

  1. (SELECT a AS b FROM t) UNION (SELECT ...) ORDER BY b;
    (SELECT a AS b FROM t) UNION (SELECT ...) ORDER BY a;
    To apply ORDER BY or LIMIT to an individual SELECT, 
    place the clause inside the parentheses that enclose the SELECT:   
  2. (SELECT a AS b FROM t) UNION (SELECT ...) ORDER BY b;
    (SELECT a AS b FROM t) UNION (SELECT ...) ORDER BY a;
    To apply ORDER BY or LIMIT to an individual SELECT, 
    place the clause inside the parentheses that enclose the SELECT:  

为了对单个SELECT使用ORDER BY或LIMIT,应把子句放入圆括号中。圆括号包含了SELECT:

代码 复制代码

  1. (SELECT a FROM tbl_name WHERE a=10 AND B=1 ORDER BY a LIMIT 10)
    UNION(SELECT a FROM tbl_name WHERE 
    a=11 AND B=2 ORDER BY a LIMIT 10);   
  2. (SELECT a FROM tbl_name WHERE a=10 AND B=1 ORDER BY a LIMIT 10)
    UNION(SELECT a FROM tbl_name WHERE 
    a=11 AND B=2 ORDER BY a LIMIT 10); 

二 实例扩展

MySQLunion可以对同一个表的两次查询联合起来. 这样做的益处也非常明显, 比如在blog应用中, 可以利用一条sql语句实现置顶blog和普通blog的分页显示.

代码 复制代码

  1. (   
  2. SELECT *   
  3. FROM `blog`   
  4. WHERE top=1   
  5. ORDER BY created DESC   
  6. )   
  7. UNION (   
  8. SELECT *   
  9. FROM `blog`   
  10. WHERE top = 0   
  11. ORDER BY created DESC   
  12. ) LIMIT 2 , 3   
  13.  

以上的相关内容就是对MySQLunion语法的介绍,望你能有所收获。
 

【编辑推荐】

  1. MySQL命令行的常用命令介绍
  2. MySQL数据库所支持的三个引擎
  3. MySQL数据类型与相应的建库策略
  4. Mysql临时表的具体使用方案
  5. MySQL连接池的实际配置问题
责任编辑:佚名 来源: 博客园
相关推荐

2009-11-16 10:40:02

PHP上传文件代码

2009-11-16 10:49:43

PHP上传文件代码

2009-11-17 17:17:50

PHP上传多个文件

2010-07-16 17:03:35

SQL Server

2009-10-29 13:46:14

VB.NET DES加

2009-11-13 10:01:50

ADO.NET CAS

2009-11-03 11:06:40

VB.NET事件

2021-05-26 08:02:03

ThreadLocal多线程多线程并发安全

2009-11-04 09:02:34

ADO.NET _C

2009-08-19 15:38:59

C#代码

2017-07-24 09:45:15

JavaScript语法代码

2013-09-09 09:50:27

代码语法工具

2009-11-02 09:45:23

VB.NET文件系统对

2009-11-27 15:13:00

PHP静态变量stat

2010-05-18 17:24:44

MySQL修改表字段

2010-05-31 14:59:36

PHP + MySQL

2014-03-14 10:56:59

语法高亮代码高亮

2017-07-26 17:38:10

JavaScriptBabel

2009-10-27 10:58:00

VB.NET文件名排序

2009-10-28 15:18:46

VB.NET网络应用
点赞
收藏

51CTO技术栈公众号