选择行直到满足条件

 zoey 发布于 2023-01-19 15:57

我想编写一个Oracle查询,该查询返回一组特定的信息。使用下表,如果给定一个id,它将返回ID和B的值。此外,如果B = T,它还将返回下一行。如果下一行具有B = T,它将返回该值,依此类推,直到遇到F。

因此,给定3,它将仅返回一行:(3,F)。给定4它将返回3行:((4,T),(5,T),(6,F))

id B
1 F
2 F
3 F
4 T
5 T
6 F
7 T
8 F

先感谢您!

1 个回答
  • 使用子查询找出应该在什么位置停止,然后将所有行从起点返回到计算出的终点。

    SELECT
      *
    FROM
      yourTable
    WHERE
          id >= 4
      AND id <= (SELECT MIN(id) FROM yourTable WHERE b = 'F' AND id >= 4)
    

    注意,这假设最后一条记录始终为“ F”。您可以使用来处理最后一个为“ T”的记录COALESCE

    SELECT
      *
    FROM
      yourTable
    WHERE
          id >= 4
      AND id <= COALESCE(
                  (SELECT MIN(id) FROM yourTable WHERE b = 'F' AND id >= 4),
                  (SELECT MAX(id) FROM yourTable                          )
                )
    

    2023-01-19 15:59 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有