SQL вернуть rownum определенной строки? (с использованием Oracle db) - PullRequest
2 голосов
/ 11 февраля 2009

В Oracle 10g у меня есть этот SQL:

select dog.id as dogId from CANINES dog order by dog.codename asc

, который возвращает:

id
--
204
203
206
923

Я хочу расширить этот запрос, чтобы определить oracle rownum dog.id в этом наборе результатов.

Я пытался

select rownum from 
(select dog.id as dogId from CANINES dog order by dog.codename asc) 
where dog.id=206

Но это не очень хорошо работает (возвращает 1 независимо от того, с каким dog.id я соответствую) Я ожидал, чтобы вернуться 3.

Спасибо за вашу помощь!


Примечания

http://www.oracle.com/technology/oramag/oracle/06-sep/o56asktom.html

Я почти уверен, что мне не нужно использовать rowid

Ответы [ 4 ]

9 голосов
/ 11 февраля 2009

Я подозреваю, что вы хотите использовать аналитическую функцию (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 не был уникальным, RANK, 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
2 голосов
/ 11 февраля 2009

Если вам нужен уникальный идентификатор каждой строки в таблице, вам нужен ROWID, а не ROWNUM.

ROWNUM - это псевдостолбец, который может меняться каждый раз, когда исполняется бит SQL (он обрабатывается во время запроса)

0 голосов
/ 26 января 2011

Для этого было бы лучше изменить таблицу и добавить последовательность. Это может стать липким, если вы собираетесь удалять строки. Где, возможно, лучше будет использовать столбец состояния или мотив начала-конца-даты, чтобы решить, какие строки активны и должны быть возвращены.

0 голосов
/ 11 февраля 2009

Посмотрите, работает ли это для вас:

Ответ

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')
...