Подтвердить что ты не робот

Row_Number() с запросом объединения

У меня есть запрос sql, который возвращает строки из двух таблиц с одинаковыми именами столбцов. Мне нужен номер строки всех записей в полном наборе результатов.

Ниже приведен запрос

select Id, VersionNumber from documents where id=5 
Union all  
select Id, VersionNumber from versions where id=5
order by VersionNumber desc

Как это сделать?

EDIT: И что, если мне нужно только вернуть row_num, где VersionNumber позволяет сказать 5.

4b9b3361

Ответ 1

Попробуйте следующее:

SELECT *, ROW_NUMBER() OVER(ORDER BY Id) ROW_NUM
  FROM (
        select Id, VersionNumber from documents where id=5 
        Union all  
        select Id, VersionNumber from versions where id=5
       ) a
order by VersionNumber desc

Для фильтрации по версии 5 используйте:

SELECT * 
FROM   (SELECT *, 
               Row_number() OVER(ORDER BY versionnumber DESC, id) row_num 
        FROM   (SELECT id, 
                       versionnumber 
                FROM   documents 
                WHERE  id = 5 
                UNION ALL 
                SELECT id, 
                       versionnumber 
                FROM   versions 
                WHERE  id = 5) a) b 
WHERE  version = 5