如何在 SELECT 查询中设置条件 LIMIT?

How to make conditional LIMIT in SELECT query?

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

如果 select 查询的计数是 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

您可以使用 window 函数:

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选择最有效的查询计划。

参见: