登录
首页 >  数据库 >  MySQL

聊聊MySQL in 查询后怎么按照查询条件顺序返回结果

来源:SegmentFault

时间:2023-01-19 11:19:46 145浏览 收藏

本篇文章向大家介绍《聊聊MySQL in 查询后怎么按照查询条件顺序返回结果》,主要包括MySQL、排序、数据库、数据库排序,具有一定的参考价值,需要的朋友可以参考一下。

从示例讲起

我们都非常习惯通过 MySQL 的 IN 函数来查询特定集合的数据,比如为了在 books 表中找出李雷、韩梅梅和安华写的书,我们可以有如下的 SQL:

SELECT * FROM books WHERE `books`.`author` IN ('李雷','韩梅梅','安华');

注意: 可以通过 SQL Fiddle 查看以上示例。

数据库返回如下结果:

authortitle
安华暴走漫画
李雷蓝色生死恋
韩梅梅冰与火之歌
韩梅梅天国的阶梯
李雷这个杀手不太冷
韩梅梅阿甘正传

虽然这样确实能够返回所有李雷、韩梅梅和安华写过的书,但是返回的数据的排序方式是默认按照数据在数据库中的存储顺序,假如我们需要的返回结果是同时按照 IN 查询条件里边的参数顺序来排序呢?这个时候我们就需要利用到 MySQL FIELD 这个函数了,FIELD 函数本来是 MySQL 提供用来查询某一个字符串在给定字符串元组中的索引位置的,比如这个官方例子:

SELECT FIELD('ej', 'Hej', 'ej', 'Heja', 'hej', 'foo'); # -> 2

如果将其应用在

  • FIELD 函数结合 ORDER BY 可以帮助我们将查询结果集按照参数列表顺序返回;

  • FIELD 函数结合 ORDER BY 的方式可以帮助我们在数据库层面完成排序,简化了业务代码逻辑;

  • FIELD 函数结合 ORDER BY 可能带来 SQL 兼容性以及性能方面的问题;

  • 在确认项目数据库不大可能为 MySQL
    之外的数据库的前提下,查询数据量少或者需要保持业务代码简洁的场景下,我建议可以采用 FIELD 函数排序;而在数据量庞大的情况下,或者不大可能出现大量 N+1 查询的情况下,我建议可以采用先在数据库中查询数据集(只查询 IN 条件,不排序)再到内存中通过业务代码排序(比如 Ruby 的 Array#sort_by)的方式。

  • 好了,本文到此结束,带大家了解了《聊聊MySQL in 查询后怎么按照查询条件顺序返回结果》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!

    声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
    相关阅读
    更多>
    最新阅读
    更多>
    课程推荐
    更多>
    评论列表