postgresql выбрать отдельную последнюю запись - PullRequest
0 голосов
/ 21 ноября 2018

У меня есть таблица типа:

id  fkey  srno  remark  date
1   A001  1
2   A001  2
3   A002  1
4   A003  1 
5   A002  2

Я хочу отдельную последнюю запись, основанную на максимальном srno, например

2  A001  2
4  A003  1
5  A002  2

Ответы [ 4 ]

0 голосов
/ 21 ноября 2018

Вы можете использовать подзапрос с оператором IN

with tab(id, fkey, srno) as 
(
 select 1,'A001',1 union all
 select 2,'A001',2 union all    
 select 3,'A002',1 union all
 select 4,'A003',1 union all    
 select 5,'A002',2   
)
select *
  from tab
 where ( fkey, srno ) in
 (
  select fkey, max(srno)
    from tab
   group by fkey
 );

id  fkey    srno
2   A001     2
4   A003     1
5   A002     2

Rextester Demo

0 голосов
/ 21 ноября 2018

используйте оконную функцию row_number()

select * from (
select *,row_number() over(PARTITION by fkey order by srno desc) rn from table1 t1 
) t where rn=1

Вы можете написать это с помощью cte

with cte as
(
    select *,row_number() over(PARTITION by fkey order by srno desc) rn from 
    table_name t1
) select * from cte where rn=1
0 голосов
/ 21 ноября 2018

Лучший способ сделать это в Postgres - использовать DISTINCT ON:

SELECT DISTINCT ON (fkey) id, fkey, srno
FROM yourTable
ORDER BY fkey, srno DESC;

enter image description here

Демо

0 голосов
/ 21 ноября 2018

Вы можете использовать коррелированный подзапрос

select * from tablename where srno in
(select max(srno) from tablename b where a.fkey=b.fkey)
...