记录:1221 - Incorrect usage of UNION and ORDER BY...【亲测有效】

简介: 记录:1221 - Incorrect usage of UNION and ORDER BY...【亲测有效】

一、前言🔥


👨‍🎓作者:bug菌

✏️博客:CSDN掘金

💌公众号:猿圈奇妙屋

🚫特别声明:原创不易,转载请附上原文出处链接和本文声明,谢谢配合。

🙏版权声明:文章里可能部分文字或者图片来源于互联网或者百度百科,如有侵权请联系bug菌处理。

      哈喽,小伙伴们,我是bug菌呀👀,不知不觉就一年又4月,正是踏青郊游的好时节。可上海疫情,除了在家远程办公就是看点技术顺便卷点文章。这不是4月又出了更文活动,逼自己一把,坚持每天做点内容输出,养成写作习惯,将来你会回来感谢曾经的自己坚持了一把才有此刻的辉煌成就。

       小伙伴们在批阅文章的过程中如果觉得文章对您有一丝丝帮助,还请别吝啬您手里的赞呀,大胆的把文章点亮👍吧,您的点赞三连(收藏⭐️+关注👨‍🎓+留言📃)就是对bug菌我创作道路上最好的鼓励与支持😘。时光不弃🏃🏻‍♀️,掘金不停💕,加油☘️


二、环境说明🔥


**环境:**navicat 11 + mysql5.6 + Windows11


三、摘要 🔥


如下是我在执行sql时完整报错截图:

网络异常,图片无法展示
|


      当看到报错还挺纳闷的,我就使用了一下[ union ]操作符,咋还拼接有错了,又没有列参数不对,都是b.*,讲道理不是操作符的问题。仔细一看,报错代码1221。

完整报错如右:1221 - Incorrect usage of UNION and ORDER BY


四、 排错 🔥


      看到此错,瞬间脑海中浮现了我大学时带我数据库的罗老师,他千叮咛万嘱咐,说在使用 【union】操作符时,第一是列数量,第二是与 order by 联合使用...还有啥来着,我给忘了,但是此报错真是第二点造就的,因为【union】在没有括号的情况下只能使用一个order by,所以对于上述例子,如果你也是使用union但是使用了多个 order by,那么石锤你也遇到跟我一样的bug了。


      所以,针对该问题,我有两种解决思路,仅供参考哈。


五、解决方案 🔥


思路1:

      由于order by不能直接出现在union的子句中,但是可以出现在子句的子句中。所以我们将结果进行子集,分别再用一层select * 查询。切记要给定一下子集命名。

如下是具体sql执行及执行结果。明显是可以看到排序生效了。


网络异常,图片无法展示
|


思路2:

      虽然该方式不是很推荐,但是也是一种解决方案,与方案一类似,但是就是将查询结果用括号括起,但有一点虽然不报错,但是排序字段不生效。


网络异常,图片无法展示
|


      所以要想在排序字段生效,那就得使用order by的同时搭配limit 使用,,这样order by排序才会对单独每个子集进行排序处理,否则虽然不加也不会报错,但是排序字段是不起效果的,这点我是亲测已做验证,大家放心使用,但选择此方案也得大概明知查询子集数量最大不会超过多少的前提下,比如我设置100,明显是知道不可能会有100条数据的。


网络异常,图片无法展示
|


      所以针对上述两种方案,依据你们的业务定,我在这推荐使用方案一,明显可拓展性比方案二要好,具体如何抉择,就看你们自己的啦,我也是将可解性都给大家诺列啦。

... ...


      ok,以上这样就好啦,如果还想学习更多,你可以看看我的往期热文推荐哦,每天积累一个奇淫小知识,日积月累下去,你一定能成为令人敬仰的大佬的。好啦,咱们下期见~


六、往期推荐🔥



七、文末🔥


      如果还想要学习更多,小伙伴们可关注bug菌专门为大家创建的专栏《SpringBoot零基础入门》,从无到有,从零到一!希望能帮到大家。

      我是bug菌,一名想走👣出大山改变命运的程序猿。接下来的路还很长,都等待着我们去突破、去挑战。来吧,小伙伴们,我们一起加油!未来皆可期,fighting!



目录
相关文章
|
SQL Oracle 关系型数据库
【MySQL异常】1093 - You can‘t specify target table ‘daily_job‘ for update in FROM clause
【MySQL异常】1093 - You can‘t specify target table ‘daily_job‘ for update in FROM clause
187 0
|
1月前
|
SQL 关系型数据库 数据库
postgresql报:ERROR: column “i“ of relation “test“ does not exist LINE 1: UPDATE怎么解决?
解决“ERROR: column "i" of relation "test" does not exist”错误的关键在于核实列名的准确性,修正更新语句,确保列名的引用正确无误,并考虑到任何可能影响列名引用的表别名、大小写、特殊字符或动态SQL生成等因素。通过上述步骤,你应该能有效定位并解决问题,保证SQL语句的正确执行。
311 0
|
6月前
|
Java 数据库连接 mybatis
项目移植到原先mybasis项目里出现BindingException: Invalid bound statement (not found): **selectPage
项目移植到原先mybasis项目里出现BindingException: Invalid bound statement (not found): **selectPage
63 1
|
存储 缓存 大数据
Starrocks执行查询报错:Memory of process exceed limit. Used: XXX, Limit: XXX. Mem usage has exceed the limit of BE
Starrocks执行查询报错:Memory of process exceed limit. Used: XXX, Limit: XXX. Mem usage has exceed the limit of BE
|
SQL 关系型数据库 MySQL
mysql使用ORDER BY和GROUP BY
mysql使用ORDER BY和GROUP BY
57 0
|
存储 SQL 关系型数据库
1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column的解决办法
1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column的解决办法
184 0
|
SQL 关系型数据库 MySQL
解决Mysql5.7以上版本, 使用group by抛出Expression #1 of SELECT list is not in GROUP BY clause and contains no异常
解决Mysql5.7以上版本, 使用group by抛出Expression #1 of SELECT list is not in GROUP BY clause and contains no异常
132 0
|
SQL 关系型数据库 MySQL
postgre分页查询报错:ERROR: LIMIT #,# syntax is not supported 建议:Use separate LIMIT and OFFSET clauses
postgre分页查询报错:ERROR: LIMIT #,# syntax is not supported 建议:Use separate LIMIT and OFFSET clauses
365 0
postgre分页查询报错:ERROR: LIMIT #,# syntax is not supported 建议:Use separate LIMIT and OFFSET clauses
|
SQL 关系型数据库 MySQL
[Err] 1294 - Invalid ON UPDATE clause for 'comment_time' column【详细解决办法】
[Err] 1294 - Invalid ON UPDATE clause for 'comment_time' column【详细解决办法】
732 0
[Err] 1294 - Invalid ON UPDATE clause for 'comment_time' column【详细解决办法】
SAP QM 执行事务代码QA11 报错- Selected set code does not exist, or data entered is incomplete-
SAP QM 执行事务代码QA11 报错- Selected set code does not exist, or data entered is incomplete-
SAP QM 执行事务代码QA11 报错- Selected set code does not exist, or data entered is incomplete-