Выберите 15 лучших записей из каждой группы - PullRequest
1 голос
/ 07 октября 2019

Я хочу выбрать 10 торговых счетов, выбрать 15 лучших записей транзакций для каждого торгового счета размером страницы 10 * 50?

У меня есть этот запрос, который дает мне лучшие записи, где мне нужно исправить, чтобы выбрать «15 лучших записей для каждого идентификатора торгового счета», а не только 150 лучших записей.

Любойуказатели, предложения, исправления кода приветствуются!

SELECT * FROM (
             SELECT account_id,transaction_id,ROWNUM RNUM
             FROM transactions 
             WHERE status='P' AND ROWNUM < ( (p_page_number * p_page_size) + 1)
             GROUP BY account_id,transaction_id, ROWNUM
             ORDER BY account_id                 
             ) a
      WHERE rnum >= ( ( (p_page_number - 1) * p_page_size) + 1);

Ответы [ 2 ]

2 голосов
/ 07 октября 2019

Вы можете использовать функцию окна DENSE_RANK() для назначения номеров групп строкам и ROW_NUMBER() для назначения серийного номера в каждой группе. Тогда фильтрация проста.

Например:

select *
from (
  select
    account_id, 
    transaction_id,
    dense_rank() over(order by account_id) as g,
    row_number() over(partition by account_id order by transaction_id) as rn
  from transactions
  where status = 'P'
) x
where g <= 10 -- the first 10 groups (accounts)
  and rn <= 15 -- the first 15 transactions within each group
1 голос
/ 07 октября 2019

Это даст вам «15 лучших записей для каждого идентификатора торгового счета»:

SELECT *
FROM (
  SELECT 
    account_id, 
    transaction_id, 
    ROW_NUMBER() OVER(
      PARTITION BY account_id -- Break into groups of merchants
      ORDER BY transaction_id -- Assign row number based on transaction, within merchants
    ) RowNum
  FROM transactions
  WHERE status='P'
) src
WHERE src.RowNum <= 15
ORDER BY account_id, transaction_id

Я не совсем уверен относительно того, как ваши p_page_number, p_page_size, and ROWNUM параметры вступают в игру.

...