warldge 2023-02-16 00:22 采纳率: 52.6%
浏览 36
已结题

SQL布尔字段排序问题

SQL布尔字段排序问题
在一个查询中返回的是多列, 我想让其中布尔字段 isReady 的值为 true 的那些先返回, 再返回值为空的那些, 最后返回值为 false 的那些, 请问这种 order by 该怎么写?

  • 写回答

3条回答 默认 最新

  • 社区专家-Monster-XH 2023-02-16 00:32
    关注

    基于Monster 组和GPT的调写:
    用 CASE 表达式在 ORDER BY 子句中对布尔字段进行排序。具体来说,你可以按以下方式编写查询:

    SELECT column1, column2, isReady
    FROM your_table
    ORDER BY
      CASE 
        WHEN isReady = true THEN 0
        WHEN isReady IS NULL THEN 1
        ELSE 2
      END
    
    
    

    这个查询会先对 isReady 为 true 的记录进行排序,然后是值为空的记录,最后是值为 false 的记录。

    CASE 表达式将 isReady 列值映射到 0, 1, 或 2,以使布尔字段正确排序。

    请注意,如果你使用的是 PostgreSQL 数据库,则可以使用 NULLS FIRST 或 NULLS LAST 关键字指定空值应该在排序中出现的位置。

    
    
    SELECT column1, column2, isReady
    FROM your_table
    ORDER BY
      CASE 
        WHEN isReady = true THEN 0
        ELSE 2
      END NULLS LAST
    

    这将首先对 isReady 为 true 的记录进行排序,然后对空值进行排序,并将它们放在最后,最后是值为 false 的记录。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月24日
  • 已采纳回答 2月16日
  • 创建了问题 2月16日

悬赏问题

  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法