2

在 Oracle 10g 中,我有这个 SQL:

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

返回:

id
--
204
203
206
923

我想扩展此查询以确定此结果集中 dog.id 的 oracle rownum。

我试过了

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

但这不是很好(无论我匹配哪个 dog.id,它都会返回 1)。我期待着回来 3。

谢谢你的帮助!


笔记

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

我很确定我不需要使用 rowid

4

4 回答 4

9

我怀疑您想要的是使用分析函数(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

如果 CANINES 表中的 ID 列不是唯一的,则 RANK、DENSE_RANKROW_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
于 2009-02-10T23:24:52.380 回答
2

如果您要查找表中每一行的唯一标识符,则需要 ROWID,而不是 ROWNUM。

ROWNUM 是一个伪列,每次执行一点 SQL 时都会发生变化(在查询时计算出来)

于 2009-02-10T21:14:25.987 回答
0

看看这是否适合你:

回答

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')
于 2009-02-10T21:18:32.887 回答
0

为了做到这一点,最好改变表并添加一个序列。如果您打算删除行,这可能会变得棘手。在哪里,也许更好的做法是使用状态列或 start-end-date 主题来决定哪些行是活动的并且应该返回。

于 2011-01-26T19:22:43.617 回答