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

Posted bug菌¹

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了记录:1221 - Incorrect usage of UNION and ORDER BY...亲测有效相关的知识,希望对你有一定的参考价值。

👨‍🎓作者:bug菌

✏️博客:CSDN掘金

💌公众号:猿圈奇妙屋

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

🙏版权声明:文章里可能部分文字或者图片来源于互联网或者百度百科,如有侵权请联系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条数据的。

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

... ...

         好啦,以上就是解决mysql union all报错的全部教学啦。如果对你有所帮助,还请不要忘记给bug菌[ 三连支持 ]哟。如果想获得更多的学习资源或者想和更多的技术爱好者一起交流,可以关注我的公众号『猿圈奇妙屋』,后台回复关键词领取学习资料、大厂面经、面试模板等海量资源,就等你来拿。


五、文末🔥

        如果你还想要学习更多,小伙伴们大可关注bug菌专门为你们创建的专栏《bug调优》,都是我一手打下的江山,持续更新中,希望能帮助到更多小伙伴们。

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

        最后送大家两句我很喜欢的话,与诸君共勉!


☘️做你想做的人,没有时间限制,只要愿意,什么时候都可以start。

🍀你能从现在开始改变,也可以一成不变,这件事,没有规矩可言,你可以活出最精彩的自己。


​​​​

💌如果文章对您有所帮助,就请留下您的吧!(#^.^#);

💝如果喜欢bug菌分享的文章,就请给bug菌点个关注吧!(๑′ᴗ‵๑)づ╭❤~;

💗如果对文章有任何疑问,还请文末留言或者加群吧【QQ交流群:708072830】;

💞鉴于个人经验有限,所有观点及技术研点,如有异议,请直接回复参与讨论(请勿发表攻击言论,谢谢);

💕版权声明:原创不易,转载请附上原文出处链接和本文声明,版权所有,盗版必究!!!谢谢。

以上是关于记录:1221 - Incorrect usage of UNION and ORDER BY...亲测有效的主要内容,如果未能解决你的问题,请参考以下文章

MySQL错误:ERROR 1221 (HY000): Incorrect usage of DB GRANT and GLOBAL PRIVILEGES

MySQL案例02:ERROR 1221 (HY000): Incorrect usage of DB GRANT and GLOBAL PRIVILEGES

.NET Core EF框架使用SQL server 2008数据库分页问题:Incorrect syntax near 'OFFSET'. Invalid usage of the

记录一次mysql时间插入错误(Data truncation: Incorrect datetime value)

记录使用vsftp虚拟用户完整搭建成功后登录报错530 Login incorrect. Login failed

记录:MySQL报错1075 - Incorrect table defintion;there can be only...解决方案