为什么Oracle用fetch更改rowid?

Gab*_*son 0 oracle plsql

我有这样的查询:

select w.rowid, w.waclogin
  from tableA w, tableB wa, tableC a
 where wa.alucod = a.alucod
   and w.waclogin = wa.waclogin
   and a.cpf = '31808013875'
   and rownum <= 1;
Run Code Online (Sandbox Code Playgroud)

结果是:

ROWID               WACLOGIN
AAA0CEAHSAABE07ABA  31808013875
Run Code Online (Sandbox Code Playgroud)

但是当我使用fetch(为了提高性能)时,返回的rowid是不同的:

select w.rowid, w.waclogin
  from tableA w, tableB wa, tableC a
 where wa.alucod = a.alucod
   and w.waclogin = wa.waclogin
   and a.cpf = '31808013875'
 fetch first row only;
Run Code Online (Sandbox Code Playgroud)

结果是:

ROWID               WACLOGIN
AAA0DMAHaAAA+ZcAAX  31808013875
Run Code Online (Sandbox Code Playgroud)

为什么要获取更改行号?对我来说,这没有道理。

更新资料

使用提取时,返回的行ID来自表B,而不是表A。

来自3个表格的行ID

Jus*_*ave 5

有两行tableA具有相同的wacLogin值(但显然具有不同的rowID值)。您的查询都没有指定,order by因此返回的那些行是任意的。大概,两个查询使用的查询计划略有不同,因此每个查询返回一个不同的任意行。当然,明天,如果查询计划或表的物理组织发生变化,则其中一个查询或两个查询都可以开始返回不同的任意行。如果您希望在两种情况下都返回同一行,则需要使两个查询都具有确定性,该order by子句使用对结果进行唯一排序的子句。

  • 依靠ROWID也不是一个好习惯-实际上,它们可以更改,最好使用UK / PK来指定行 (5认同)