前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysql union 的用法

mysql union 的用法

作者头像
明明如月学长
发布2021-08-27 11:28:09
6530
发布2021-08-27 11:28:09
举报

union 的用法 (一般用于多张表的union)

合并查询结果

将两次或者两次以上的结果合并在一起

要求: 两次查询的列数一致

推荐,查询每一列,相对应的列类型是一样的

多次sql语句 取出 的列名可以不一致,此时以取第一个sql 的列名为准。

如果不同的语句中取出的行 有每个列的值都相同,那么相同的行将被合并成一行(去重复)

如果不想去重复union加上 all

创建表格

create table ta

(id char(1) default null,

num int not null default 0

) engine=InnoDB  charset=utf8;

insert into ta

(id,num)

values

('a',10),

('b',20),

('c',30),

('d',40);

mysql <wbr>union <wbr>的用法
mysql <wbr>union <wbr>的用法

create table tb

(id char(1) default null,

num int not null default 0

) engine=InnoDB  charset=utf8;

insert into tb

(id,num)

values

('a',50),

('b',60),

('c',70),

('d',80);

mysql <wbr>union <wbr>的用法
mysql <wbr>union <wbr>的用法

1  合并 两张表格

mysql <wbr>union <wbr>的用法
mysql <wbr>union <wbr>的用法

2  合并两张表单 把相同id下的数值sum求和

mysql <wbr>union <wbr>的用法
mysql <wbr>union <wbr>的用法

发现问题

使用聚合 函数时 不许有空格

Sum(num)

mysql <wbr>union <wbr>的用法
mysql <wbr>union <wbr>的用法

Sum (num)

mysql <wbr>union <wbr>的用法
mysql <wbr>union <wbr>的用法

将会把 sum  识别为 表 报该数据库下不存在该表单错误

Error 1630(42000)

注意:如果子句里 有 order by | limit 需要 union 两边加小括号

例如

(select  good_id,cat_id,goods_name,shop_price from goods _id =where cat_id = 4 order by

shop_price desc )union (select  good_id,cat_id,goods_name,shop_price from goods _id =where

cat_id = 5 order by shop_price desc);

子查询(完整)
子查询(完整)

但是 容易有误

解决方案

1  order by 尽量放在最后使用 即岁最终合并后的结果 进行排序

(select  good_id,cat_id,goods_name,shop_price from goods _id =where cat_id = 4 )union

(select  good_id,cat_id,goods_name,shop_price from goods _id =where cat_id = 5  order by

shop_price desc;

子查询(完整)
子查询(完整)

2  每个子语句 加上limit

子查询(完整)
子查询(完整)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2015/06/20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档