Re: first_value/last_value

Поиск
Список
Период
Сортировка
От Melvin Davidson
Тема Re: first_value/last_value
Дата
Msg-id CANu8FixVmZpbhRoH9VmX=9P1jw66wF_9_dmbRDFZE1x+o7nnxg@mail.gmail.com
обсуждение исходный текст
Ответ на Re: first_value/last_value  (Adam Brusselback <adambrusselback@gmail.com>)
Ответы Re: first_value/last_value  (Tom Smith <tomsmith1989sk@gmail.com>)
Список pgsql-general


On Wed, May 18, 2016 at 10:36 PM, Adam Brusselback <adambrusselback@gmail.com> wrote:
Here is an example that works in a single query.  Since you have two different orders you want the data back in, you need to use subqueries to get the proper data back, but it works, and is very fast.

CREATE TEMPORARY TABLE foo AS 
SELECT generate_series as bar
FROM generate_series(1, 1000000);

CREATE INDEX idx_foo_bar ON foo (bar);


SELECT *
FROM (
SELECT bar
FROM foo
ORDER BY bar asc
LIMIT 1
) x
UNION ALL 
SELECT *
FROM (
SELECT bar
FROM foo
ORDER BY bar desc
LIMIT 1
) y;

DROP TABLE foo;

Seems to me SELECT min(<column>),  max(<column>) FROM deja.vu ; would also work.


--
Melvin Davidson
I reserve the right to fantasize.  Whether or not you
wish to share my fantasy is entirely up to you.

В списке pgsql-general по дате отправления:

Предыдущее
От: Adam Brusselback
Дата:
Сообщение: Re: first_value/last_value
Следующее
От: Tom Smith
Дата:
Сообщение: Re: first_value/last_value