如何在 SELECT 查询中设置条件 LIMIT?
How to make conditional LIMIT in SELECT query?
我想用 limit
和 offset
做条件 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选择最有效的查询计划。
参见:
- Select next or first row
- Combine multiple SELECT statements
- Way to try multiple SELECTs till a result is available?
我想用 limit
和 offset
做条件 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选择最有效的查询计划。
参见:
- Select next or first row
- Combine multiple SELECT statements
- Way to try multiple SELECTs till a result is available?