MySQL:The used SELECT statements have a different number of columns

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 执行SQL报错:The used SELECT statements have a different number of columns

执行SQL报错:The used SELECT statements have a different number of columns

以上翻译:使用的SELECT语句具有不同数量的列

原因:我们在 SQL 语句中使用了 UNION 连接两张表时,查询字段数量不一致导致

# 效果展示



我们需要将数据展示如上图所示

# 错误案例

SELECT
  a.quantity AS in_quantity,
  a.price AS in_price,
  (a.quantity * a.price) AS in_amount,
  0 AS out_quantity,
  0 AS out_price,
  0 AS out_amount 
FROM
  store_in_detail a 
WHERE
  a.sku_id = 1345 
UNION ALL
SELECT
  b.quantity AS out_quantity,
  b.price AS out_price,
  (b.quantity * b.price) AS out_amount 
FROM
  store_out_detail b 
WHERE
  b.sku_id = 1345

我们通过入库表 连接 出库表,得出商品 id = 1345 的出入库情况

执行SQL报错:The used SELECT statements have a different number of columns (使用的SELECT语句具有不同数量的列)

# 原因分析

我们在查询入库单,查询了四个字段:入库数量,入库单价,入库金额,出库数量(默认0),出库单价(默认0),出库金额(默认0)

而查询出库单,只查询了两个字段:出库数量,出库单价,出库金额

两次查询的字段数量不一致,导致 SQL 异常

# 正确实例

SELECT
  a.quantity AS in_quantity,
  a.price AS in_price,
  (a.quantity * a.price) AS in_amount,
  0 AS out_quantity,
  0 AS out_price,
  0 AS out_amount 
FROM
  store_in_detail a 
WHERE
  a.sku_id = 1345 
UNION ALL
SELECT
  0 AS in_quantity,
  0 AS in_price,
  0 AS in_amount,
  b.quantity AS out_quantity,
  b.price AS out_price,
  (b.quantity * b.price) AS out_amount  
FROM
  store_out_detail b 
WHERE
  b.sku_id = 1345

SQL 执行成功

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6月前
|
关系型数据库 MySQL
【MySQL】——Select查询语句知识点练习(其一)
【MySQL】——Select查询语句知识点练习(其一)
|
6月前
|
SQL 关系型数据库 MySQL
在云数据仓库AnalyticDB MySQL版中,有几个参数可能影响SELECT查询的执行及其稳定性
在云数据仓库AnalyticDB MySQL版中,有几个参数可能影响SELECT查询的执行及其稳定性【1月更文挑战第16天】【1月更文挑战第80篇】
342 4
|
6月前
|
SQL 关系型数据库 MySQL
MySQL技能完整学习列表3、SQL语言基础——1、SQL(Structured Query Language)简介——2、基本SQL语句:SELECT、INSERT、UPDATE、DELETE
MySQL技能完整学习列表3、SQL语言基础——1、SQL(Structured Query Language)简介——2、基本SQL语句:SELECT、INSERT、UPDATE、DELETE
117 0
|
8天前
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
2月前
|
SQL 关系型数据库 MySQL
MySQL 8.0报错--1118-Row size too large. The maximum row size for the used table type, not counting BLOBs,is 8126,
MySQL 8.0报错--1118-Row size too large. The maximum row size for the used table type, not counting BLOBs,is 8126,
MySQL 8.0报错--1118-Row size too large. The maximum row size for the used table type, not counting BLOBs,is 8126,
|
3月前
|
存储 关系型数据库 MySQL
在 MySQL 中使用 Insert Into Select
【8月更文挑战第11天】
463 0
在 MySQL 中使用 Insert Into Select
|
4月前
|
存储 关系型数据库 文件存储
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
47 2
|
4月前
|
网络协议 关系型数据库 MySQL
启动mysql时的异常为:[ERROR] Can‘t start server: Bind on TCP/IP port. Got error: 98: Address already in used
启动mysql时的异常为:[ERROR] Can‘t start server: Bind on TCP/IP port. Got error: 98: Address already in used
|
6月前
|
SQL 关系型数据库 MySQL
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
116 0