zoukankan      html  css  js  c++  java
  • sql的union用法

    sql中union是很常见的,尤其是创建视图时,完全离不开union。

    SQL UNION 操作符合并两个或多个 SELECT 语句的结果,UNION 内部的每个 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每个 SELECT 语句中的列的顺序必须相同。

    union包括union和union all两种语法,如下:

    SQL UNION 语法

     
    SELECT column_name(s) FROM table1
    UNION
    SELECT column_name(s) FROM table2;

    SQL UNION ALL 语法

    SELECT column_name(s) FROM table1
    UNION ALL
    SELECT column_name(s) FROM table2;

    两者的区别就是union all包括重复的数据。

    说完了语法,下面以一个简单的例子介绍下。

    先说表结构,很简单,两张表

    teacher

    student.

    可以看到,两张表的表结构是一样的。

    现在进行对first_name的union查询。

    select first_name from teacher union select first_name from student;

    查询结果如下:

    可以看到没有重复的数据。

    改为union all之后。

    select first_name from teacher union all select first_name from student;

    查询结果如下:

    可以看到,数据是重复的。

    但如果同时查询first_name和last_name呢?

    select first_name, last_name from teacher union select  first_name, last_name from student;

    结果如下:

    改为union all之后

    select first_name, last_name from teacher union all select  first_name, last_name from student;

    查询结果:

    可以看到,结果是一样的,因为first_name和last_name在一起的话判断的话,没有重复的数据。

    参考:

    http://www.w3cschool.cc/sql/sql-union.html

  • 相关阅读:
    MySQL性能优化的最佳经验
    18个网站SEO建议
    sql之left join、right join、inner join的区别
    PHP与MYSQL事务处理
    Firefox上Web开发工具库一览
    SphinxSE的安装
    python XML
    python yaml
    C语言文本处理
    Linux strace命令
  • 原文地址:https://www.cnblogs.com/wardensky/p/4145279.html
Copyright © 2011-2022 走看看