微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PostgreSQL-如何在选择查询中进行条件限制偏移量

如何解决PostgreSQL-如何在选择查询中进行条件限制偏移量

我想用order bylimit作条件offset。 如果计数为1,那么我想要最新的日期,否则我想要最新的但只有一条记录。我正在尝试以下查询

如果选择查询的计数为1,则

Select * from table_name
ORDER BY date_column LIMIT 1;

否则,

Select * from table_name
ORDER BY date_column LIMIT 1 OFFSET 1;

还有其他实现逻辑的方法吗? 预先感谢。

解决方法

最接近您当前代码的答案是将其包装在CASE WHEN语句中。如果您将其视为CASE WHEN (1) THEN (2) ELSE (3),则逻辑说明了一切。如果(1)为真,则执行(2),否则执行(3)。

SELECT *
FROM table_name
WHERE CASE WHEN (
    SELECT COUNT(*)
    FROM table_name t
  ) > 1 THEN date_column = (
    SELECT date_column
    FROM table_name t
    ORDER BY date_column LIMIT 1 OFFSET 1
  ) ELSE date_column = (
    SELECT date_column
    FROM table_name t
    ORDER BY date_column LIMIT 1
  )
LIMIT 1
,

您可以使用窗口功能:

select *
from (
    select t.*,row_number() over(order by date_column) rn,count(*) over() cnt
    from mytable t
) t
where rn = 2 or cnt = 1
,
select * from (
    Select * from table_name
    ORDER BY date_column LIMIT 2
 ) as foo ORDER BY date_column DESC LIMIT 1
,
(SELECT * FROM table_name ORDER BY date_column OFFSET 1 LIMIT 1)
UNION ALL
(SELECT * FROM table_name ORDER BY date_column LIMIT 1)
LIMIT 1

如果有两个或多个符合条件的行,第二个 SELECT永远不会执行(您可以在 EXPLAIN ANALYZE 的输出中看到)。因此,通常情况下,这是最快的方式。

子查询中的

LIMIT 1 在逻辑上是多余的,但它有助于 Postgres 选择最有效的查询计划。

见:

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。