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

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 执行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 执行成功

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
关系型数据库 MySQL
【MySQL】——Select查询语句知识点练习(其一)
【MySQL】——Select查询语句知识点练习(其一)
|
11月前
|
缓存 关系型数据库 MySQL
ThinkPHP框架show columns引发mysql性能问题
ThinkPHP框架的show columns引发mysql性能问题,结尾有关闭方式。
377 13
|
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,
1596 56
MySQL 8.0报错--1118-Row size too large. The maximum row size for the used table type, not counting BLOBs,is 8126,
|
移动开发 关系型数据库 MySQL
MySQL中的ROW_NUMBER窗口函数简单了解下
ROW_NUMBER是 MySQL8引入的窗口函数之一,它为查询结果集中的每一行分配一个唯一的顺序号(行号)。ROW_NUMBER在分页、去重、分组内排序等场景中非常有用。
727 4
|
SQL 关系型数据库 MySQL
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
334 0
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
存储 关系型数据库 MySQL
在 MySQL 中使用 Insert Into Select
【8月更文挑战第11天】
6074 0
在 MySQL 中使用 Insert Into Select
|
存储 关系型数据库 文件存储
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
199 2
|
网络协议 关系型数据库 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

推荐镜像

更多