搜索

首页  >  问答  >  正文

MySQL的联合查询[union]有什么实际的用处

MySQL的联合查询[union]有什么实际的用处?

联合查询只要求两张表字段数一致,但是字段名却可以不同,能否提供一个使用它的例子?
曾经蜡笔没有小新曾经蜡笔没有小新2757 天前1080

全部回复(3)我来回复

  • PHP中文网

    PHP中文网2017-06-10 09:51:42

    之前使用的例子,有多个信息模块的数据,需要展示,每个模块表都有一个title,id,picture字段。为减少多次的查询SQL,使用union将这些表的数据合为一个结果集返回。

    SELECT id,title,picture, 'A' AS module FROM A LIMIT 5
    UNION 
    SELECT id,title,picture, 'B' AS module FROM B LIMIT 5
    UNION
    SELECT id,title,picture, 'C' AS module FROM C LIMIT 5

    回复
    0
  • 巴扎黑

    巴扎黑2017-06-10 09:51:42

    比如说遇到一个项目,数据量超大,需要分表,同样的结构分了100多个表,那么去查询的时候需要这100个表中分别进行查询并 union all 来获取数据。

    回复
    0
  • 我想大声告诉你

    我想大声告诉你2017-06-10 09:51:42

    小技巧:

    select goods "商品", case goods when 1 then price then price*1.2 when 2 then price*1.5 else 0 end
    from talbe

    缺点:代码可读性差

    select goods, price*1.2
    from table where goods=1
    union
    select goods, price*1.5
    from table where goods=2
    union
    select goods, 0
    from table where goods not in (1, 2)

    有时候利用union可以解决一些奇怪的判断语句.比如将报表的合计一起返回

    回复
    0
  • 取消回复