如何解决PostgreSQL-如何在选择查询中进行条件限制偏移量
我想用order by
和limit
作条件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 举报,一经查实,本站将立刻删除。