1

可能会问非常愚蠢的问题:

Oracle db 中的表可以有完全重复的记录。IE:

DUP_TABLE:
 NUMBER(8,0) field_A
 NUMBER(8,0) field_B

有这个数据:

field_A field_B
123     456 
123     456

在这种情况下,数据库引擎将如何区分这些记录?

4

2 回答 2

4

Oracle(和大多数关系数据库)将允许您创建可以包含重复行的表。如果要排除重复项,只需添加一个跨表所有列的 UNIQUE 约束。

如果重复行是您想要的,当您查询表时,您将获得与表中一样多的副本,除非您有 DISTINCT 子句或某种将重复项统一到单个实例的分组。

Oracle 将每条记录存储在其内部跟踪的单独位置。用户可以 SELECT rowid FROM a_table; 要获得指向该位置的指针,但是应该首先仔细考虑为什么要这样做,因为这可能是数据库设计不佳的标志-如果两条记录应该是可区分的,则可能需要另一列带有区分它们的信息?或者,数据库管理的序列号可以提供比 rowid 更容易传达给用户的唯一编号。

重复和 rowid 的示例

讨论 rowids 随时间变化的问题

于 2013-04-28T18:20:15.690 回答
3

Oraclerowid为每一行隐式添加一个命名列。你可以这样查询rowid

select rowid, field_A, field_B from DUP_TABLE;

从您那里提取rowid可以获取有关查询记录的物理存储的更多信息:

select DBMS_ROWID.ROWID_OBJECT(rowid) "OBJECT",
       DBMS_ROWID.ROWID_RELATIVE_FNO(rowid) "FILE",
       DBMS_ROWID.ROWID_BLOCK_NUMBER(rowid) "BLOCK",
       DBMS_ROWID.ROWID_ROW_NUMBER(rowid) "ROW"
from DUP_TABLE;
于 2013-04-28T18:20:44.577 回答