SQL для возврата rownum определенной строки?(используя Oracle db)
Вопрос
В Oracle 10g у меня есть этот SQL:
select dog.id as dogId from CANINES dog order by dog.codename asc
который возвращает:
id
--
204
203
206
923
Я хочу расширить этот запрос, чтобы определить oracle rownum для a dog.id в этом результирующем наборе.
Я пытался
select rownum from
(select dog.id as dogId from CANINES dog order by dog.codename asc)
where dog.id=206
Но это работает не очень хорошо (он возвращает 1 независимо от того, с какой собакой.идентификатор, с которым я сопоставляю).Я ожидал вернуться 3.
Спасибо за вашу помощь!
Примечания
http://www.oracle.com/technology/oramag/oracle/06-sep/o56asktom.html
Я почти уверен, что мне не нужно использовать rowid
Решение
Я подозреваю, что вы хотите использовать аналитическую функцию (RANK, DENSE_RANK
, или ROW_NUMBER
), т. е.
SELECT rnk
FROM (select dog.id as dogId,
ROW_NUMBER() OVER( ORDER BY dog.codename ASC ) rnk
from CANINES dog )
WHERE dogId = 206
Если столбец ID в таблице CANINES не был уникальным, РАНЖИРУЙТЕ, DENSE_RANK
, и ROW_NUMBER
) относился бы к связям по-другому.
Если вы хотите сделать это исключительно с помощью ROWNUM,
SELECT rn
FROM (
SELECT dogId, rownum rn
FROM (select dog.id as dogId
from CANINES dog
order by dog.codename ASC) inner
) middle
WHERE dogId = 206
Другие советы
Если вам нужен уникальный идентификатор каждой строки в таблице, вам нужен ROWID, а не ROWNUM.
ROWNUM - это псевдоколонка, которая может меняться каждый раз, когда выполняется часть SQL (это обрабатывается во время запроса).
Посмотрим, сработает ли это для вас:
Ответ
SELECT dog1.DogID, dog1.DogName, COUNT(*) AS rownumber
FROM #ids dog1, #ids dog2
WHERE dog2.DogName <= dog1.DogName
GROUP BY dog1.DogID, dog1.DogName
ORDER BY dog1.DogName
Результаты
DogID DogName rownumber
----------- ---------- -----------
204 Dog 1 1
203 Dog 2 2
206 Dog 3 3
923 Dog 4 4
DDL
CREATE TABLE #ids (DogID int NOT NULL PRIMARY KEY, DogName varchar(10) NOT NULL)
INSERT INTO #ids (DogID, DogName) VALUES (204, 'Dog 1')
INSERT INTO #ids (DogID, DogName) VALUES (203, 'Dog 2')
INSERT INTO #ids (DogID, DogName) VALUES (206, 'Dog 3')
INSERT INTO #ids (DogID, DogName) VALUES (923, 'Dog 4')
Чтобы достичь этого, было бы лучше всего изменить таблицу и добавить последовательность.Это может привести к залипанию, если вы собираетесь удалять строки.Где, возможно, лучшей практикой было бы использовать столбец состояния или мотив даты начала-окончания, чтобы решить, какие строки активны и должны быть возвращены.