142 DBMS_ROWID
The DBMS_ROWID package lets you create ROWIDs and obtain information about ROWIDs from PL/SQL programs and SQL statements. You can find the data block number, the object number, and other ROWID components without writing code to interpret the base-64 character external ROWID. DBMS_ROWID is intended for upgrading from Oracle database version 7 to Oracle database version 8.X.
Note:
DBMS_ROWID is not to be used with universal ROWIDs (UROWIDs).
This chapter contains the following topics:
142.1 DBMS_ROWID Security Model
This package runs with the privileges of calling user, rather than the package owner SYS.
142.2 DBMS_ROWID Types
There are four DBMS_ROWID types.
These are:
-
Extension and restriction types
-
Verification types
-
Object types
-
Conversion types
Extension and Restriction Type
The types are as follows:
-
RESTRICTED—restrictedROWID -
EXTENDED—extendedROWID
For example:
rowid_type_restricted constant integer := 0; rowid_type_extended constant integer := 1;
Note:
Extended ROWIDs are only used in Oracle database version 8.Xi and higher.
Verification Types
Table 142-1 Verification Types
| Result | Description |
|---|---|
|
|
Valid |
|
|
Invalid |
For example:
rowid_is_valid constant integer := 0; rowid_is_invalid constant integer := 1;
Object Types
Table 142-2 Object Types
| Result | Description |
|---|---|
|
|
Object Number not defined (for restricted |
For example:
rowid_object_undefined constant integer := 0;
Conversion Types
Table 142-3 Conversion Types
| Result | Description |
|---|---|
|
|
Convert to/from column of |
|
|
Convert to/from string format |
For example:
rowid_convert_internal constant integer := 0; rowid_convert_external constant integer := 1;
142.3 DBMS_ROWID Exceptions
This table describes the Exceptions raised by DBMS_ROWID subprograms.
Table 142-4 Exceptions
| Exception | Description |
|---|---|
|
|
Invalid rowid format |
|
|
Block is beyond end of file |
For example:
ROWID_INVALID exception; pragma exception_init(ROWID_INVALID, -1410); ROWID_BAD_BLOCK exception; pragma exception_init(ROWID_BAD_BLOCK, -28516);
142.4 DBMS_ROWID Operational Notes
These operation notes apply to DBMS_ROWID.
-
Some of the functions in this package take a single parameter, such as a
ROWID. This can be a character or a PL/SQLROWID, either restricted or extended, as required. -
You can call the
DBMS_ROWIDfunctions and procedures from PL/SQL code, and you can also use the functions in SQL statements.Note:
ROWID_INFOis a procedure. It can only be used in PL/SQL code. -
You can use functions from the
DBMS_ROWIDpackage just like built-in SQL functions; in other words, you can use them wherever you can use an expression. In this example, theROWID_BLOCK_NUMBERfunction is used to return just the block number of a single row in theEMPtable:SELECT DBMS_ROWID.ROWID_BLOCK_NUMBER(rowid) FROM emp WHERE ename = 'KING';
-
If Oracle returns the error "ORA:452, 0, 'Subprogram '%s' violates its associated pragma' for
pragmarestrict_references, it could mean the violation is due to:-
A problem with the current procedure or function
-
Calling a procedure or function without a pragma or due to calling one with a less restrictive pragma
-
Calling a package procedure or function that touches the initialization code in a package or that sets the default values
-
142.5 DBMS_ROWID Examples
This example returns the ROWID for a row in the EMP table, extracts the data object number from the ROWID, using the ROWID_OBJECT function in the DBMS_ROWID package, then displays the object number:
DECLARE
object_no INTEGER;
row_id ROWID;
...
BEGIN
SELECT ROWID INTO row_id FROM emp
WHERE empno = 7499;
object_no := DBMS_ROWID.ROWID_OBJECT(row_id);
DBMS_OUTPUT.PUT_LINE('The obj. # is '|| object_no);
...142.6 Summary of DBMS_ROWID Subprograms
This table lists the DBMS_ROWID subprograms and briefly describes them.
Table 142-5 DBMS_ROWID Package Subprograms
| Subprogram | Description |
|---|---|
|
Returns the block number of a |
|
|
Creates a |
|
|
Returns the type and components of a |
|
|
Returns the object number of the extended |
|
|
Returns the file number of a |
|
|
Returns the row number |
|
|
Returns the absolute file number associated with the |
|
|
Converts a |
|
|
Converts an extended |
|
|
Returns the |
|
|
Checks if a |
142.6.1 ROWID_BLOCK_NUMBER Function
This function returns the database block number for the input ROWID.
Syntax
DBMS_ROWID.ROWID_BLOCK_NUMBER ( row_id IN ROWID, ts_type_in IN VARCHAR2 DEFAULT 'SMALLFILE') RETURN NUMBER;
Pragmas
pragma RESTRICT_REFERENCES(rowid_block_number,WNDS,RNDS,WNPS,RNPS);
Parameters
Table 142-6 ROWID_BLOCK_NUMBER Function Parameters
| Parameter | Description |
|---|---|
|
|
|
|
|
The type of the tablespace (bigfile/smallfile) to which the row belongs |
Examples
The example SQL statement selects the block number from a ROWID and inserts it into another table:
INSERT INTO T2 (SELECT dbms_rowid.rowid_block_number(ROWID, 'BIGFILE') FROM some_table WHERE key_value = 42);
142.6.2 ROWID_CREATE Function
This function lets you create a ROWID, given the component parts as parameters.
This is useful for testing ROWID operations, because only the Oracle Server can create a valid ROWID that points to data in a database.
Syntax
DBMS_ROWID.ROWID_CREATE ( rowid_type IN NUMBER, object_number IN NUMBER, relative_fno IN NUMBER, block_number IN NUMBER, row_number IN NUMBER) RETURN ROWID;
Pragmas
pragma RESTRICT_REFERENCES(rowid_create,WNDS,RNDS,WNPS,RNPS);
Parameters
Table 142-7 ROWID_CREATE Function Parameters
| Parameter | Description |
|---|---|
|
|
Type (restricted or extended) Set the If you specify |
|
|
Data object number ( |
|
|
Relative file number |
|
|
Block number in this file |
|
|
Returns row number in this block |
Examples
Create a dummy extended ROWID:
my_rowid := DBMS_ROWID.ROWID_CREATE(1, 9999, 12, 1000, 13);
Find out what the rowid_object function returns:
obj_number := DBMS_ROWID.ROWID_OBJECT(my_rowid);
The variable obj_number now contains 9999.
142.6.3 ROWID_INFO Procedure
This procedure returns information about a ROWID, including its type (restricted or extended), and the components of the ROWID.
This is a procedure, and it cannot be used in a SQL statement.
Syntax
DBMS_ROWID.ROWID_INFO ( rowid_in IN ROWID, rowid_type OUT NUMBER, object_number OUT NUMBER, relative_fno OUT NUMBER, block_number OUT NUMBER, row_number OUT NUMBER);
Pragmas
pragma RESTRICT_REFERENCES(rowid_info,WNDS,RNDS,WNPS,RNPS);
Parameters
Table 142-8 ROWID_INFO Procedure Parameters
| Parameter | Description |
|---|---|
|
|
|
|
|
Returns type (restricted/extended) |
|
|
Returns data object number ( |
|
|
Returns relative file number |
|
|
Returns block number in this file |
|
|
Returns row number in this block |
See Also:
Examples
This example reads back the values for the ROWID that you created in the ROWID_CREATE:
DBMS_ROWID.ROWID_INFO ( my_rowid, rid_type, obj_num, file_num, block_num, row_num, 'BIGFILE');
142.6.4 ROWID_OBJECT Function
This function returns the data object number for an extended ROWID.
The function returns zero if the input ROWID is a restricted ROWID.
Syntax
DBMS_ROWID.ROWID_OBJECT ( rowid_id IN ROWID) RETURN NUMBER;
Pragmas
pragma RESTRICT_REFERENCES(rowid_object,WNDS,RNDS,WNPS,RNPS);
Parameters
Table 142-9 ROWID_OBJECT Function Parameters
| Parameter | Description |
|---|---|
|
|
|
Note:
The ROWID_OBJECT_UNDEFINED constant is returned for restricted ROWIDs.
Examples
SELECT dbms_rowid.rowid_object(ROWID) FROM emp WHERE empno = 7499;
142.6.5 ROWID_RELATIVE_FNO Function
This function returns the relative file number of the ROWID specified as the IN parameter. (The file number is relative to the tablespace.)
Syntax
DBMS_ROWID.ROWID_RELATIVE_FNO ( rowid_id IN ROWID, ts_type_in IN VARCHAR2 DEFAULT 'SMALLFILE') RETURN NUMBER;
Pragmas
pragma RESTRICT_REFERENCES(rowid_relative_fno,WNDS,RNDS,WNPS,RNPS);
Parameters
Table 142-10 ROWID_RELATIVE_FNO Function Parameters
| Parameter | Description |
|---|---|
|
|
|
|
|
Type of the tablespace (bigfile/smallfile) to which the row belongs |
Examples
The example PL/SQL code fragment returns the relative file number:
DECLARE
file_number INTEGER;
rowid_val ROWID;
BEGIN
SELECT ROWID INTO rowid_val
FROM dept
WHERE loc = 'Boston';
file_number :=
dbms_rowid.rowid_relative_fno(rowid_val, 'SMALLFILE');
...142.6.6 ROWID_ROW_NUMBER Function
This function extracts the row number from the ROWID IN parameter.
Syntax
DBMS_ROWID.ROWID_ROW_NUMBER ( row_id IN ROWID) RETURN NUMBER;
Pragmas
PRAGMA RESTRICT_REFERENCES(rowid_row_number,WNDS,RNDS,WNPS,RNPS);
Parameters
Table 142-11 ROWID_ROW_NUMBER Function Parameters
| Parameter | Description |
|---|---|
|
|
|
Examples
Select a row number:
SELECT dbms_rowid.rowid_row_number(ROWID) FROM emp WHERE ename = 'ALLEN';
142.6.7 ROWID_TO_ABSOLUTE_FNO Function
This function extracts the absolute file number from a ROWID, where the file number is absolute for a row in a given schema and table.
The schema name and the name of the schema object (such as a table name) are provided as IN parameters for this function.
Syntax
DBMS_ROWID.ROWID_TO_ABSOLUTE_FNO ( row_id IN ROWID, schema_name IN VARCHAR2, object_name IN VARCHAR2) RETURN NUMBER;
Pragmas
pragma RESTRICT_REFERENCES(rowid_to_absolute_fno,WNDS,WNPS,RNPS);
Parameters
Table 142-12 ROWID_TO_ABSOLUTE_FNO Function Parameters
| Parameter | Description |
|---|---|
|
|
|
|
|
Name of the schema which contains the table |
|
|
Table name |
Examples
DECLARE
abs_fno INTEGER;
rowid_val CHAR(18);
object_name VARCHAR2(20) := 'EMP';
BEGIN
SELECT ROWID INTO rowid_val
FROM emp
WHERE empno = 9999;
abs_fno := dbms_rowid.rowid_to_absolute_fno(
rowid_val, 'SCOTT', object_name);Note:
For partitioned objects, the name must be a table name, not a partition or a sub/partition name.
142.6.8 ROWID_TO_EXTENDED Function
This function translates a restricted ROWID that addresses a row in a schema and table that you specify to the extended ROWID format.
Later, it may be removed from this package into a different place.
Syntax
DBMS_ROWID.ROWID_TO_EXTENDED ( old_rowid IN ROWID, schema_name IN VARCHAR2, object_name IN VARCHAR2, conversion_type IN INTEGER) RETURN ROWID;
Pragmas
pragma RESTRICT_REFERENCES(rowid_to_extended,WNDS,WNPS,RNPS);
Parameters
Table 142-13 ROWID_TO_EXTENDED Function Parameters
| Parameter | Description |
|---|---|
|
|
|
|
|
Name of the schema which contains the table (optional) |
|
|
Table name (optional). |
|
|
The following constants are defined:
|
Return Values
ROWID_TO_EXTENDED returns the ROWID in the extended character format. If the input ROWID is NULL, then the function returns NULL. If a zero-valued ROWID is supplied (00000000.0000.0000), then a zero-valued restricted ROWID is returned.
Examples
Assume that there is a table called RIDS in the schema SCOTT, and that the table contains a column ROWID_COL that holds ROWIDs (restricted), and a column TABLE_COL that point to other tables in the SCOTT schema. You can convert the ROWIDs to extended format with the statement:
UPDATE SCOTT.RIDS
SET rowid_col =
dbms_rowid.rowid_to_extended (
rowid_col, 'SCOTT", TABLE_COL, 0);Usage Notes
-
If the schema and object names are provided as
INparameters, then this function verifiesSELECTauthority on the table named, and converts the restrictedROWIDprovided to an extendedROWID, using the data object number of the table. ThatROWID_TO_EXTENDEDreturns a value, however, does not guarantee that the convertedROWIDactually references a valid row in the table, either at the time that the function is called, or when the extendedROWIDis actually used. -
If the schema and object name are not provided (are passed as
NULL), then this function attempts to fetch the page specified by the restrictedROWIDprovided. It treats the file number stored in thisROWIDas the absolute file number. This can cause problems if the file has been dropped, and its number has been reused prior to the migration. If the fetched page belongs to a valid table, then the data object number of this table is used in converting to an extendedROWIDvalue. This is very inefficient, and Oracle recommends doing this only as a last resort, when the target table is not known. The user must still know the correct table name at the time of using the converted value. -
If an extended
ROWIDvalue is supplied, the data object number in the input extendedROWIDis verified against the data object number computed from the table name parameter. If the two numbers do not match, theINVALID_ROWIDexception is raised. If they do match, the inputROWIDis returned. -
ROWID_TO_EXTENDEDcannot be used with partition tables.
See Also:
The ROWID_VERIFY Function has a method to determine if a given ROWID can be converted to the extended format.
142.6.9 ROWID_TO_RESTRICTED Function
This function converts an extended ROWID into restricted ROWID format.
Syntax
DBMS_ROWID.ROWID_TO_RESTRICTED ( old_rowid IN ROWID, conversion_type IN INTEGER) RETURN ROWID;
Pragmas
pragma RESTRICT_REFERENCES(rowid_to_restricted,WNDS,RNDS,WNPS,RNPS);
Parameters
Table 142-14 ROWID_TO_RESTRICTED Function Parameters
| Parameter | Description |
|---|---|
|
|
|
|
|
The following constants are defined:
|
142.6.10 ROWID_TYPE Function
This function returns 0 if the ROWID is a restricted ROWID, and 1 if it is extended.
Syntax
DBMS_ROWID.ROWID_TYPE ( rowid_id IN ROWID) RETURN NUMBER;
Pragmas
pragma RESTRICT_REFERENCES(rowid_type,WNDS,RNDS,WNPS,RNPS);
Parameters
Table 142-15 ROWID_TYPE Function Parameters
| Parameter | Description |
|---|---|
|
|
|
Examples
IF DBMS_ROWID.ROWID_TYPE(my_rowid) = 1 THEN my_obj_num := DBMS_ROWID.ROWID_OBJECT(my_rowid);
142.6.11 ROWID_VERIFY Function
This function verifies the ROWID.
It returns 0 if the input restricted ROWID can be converted to extended format, given the input schema name and table name, and it returns 1 if the conversion is not possible.
Note:
You can use this function in a WHERE clause of a SQL statement, as shown in the example.
Syntax
DBMS_ROWID.ROWID_VERIFY ( rowid_in IN ROWID, schema_name IN VARCHAR2, object_name IN VARCHAR2, conversion_type IN INTEGER RETURN NUMBER;
Pragmas
pragma RESTRICT_REFERENCES(rowid_verify,WNDS,WNPS,RNPS);
Parameters
Table 142-16 ROWID_VERIFY Function Parameters
| Parameter | Description |
|---|---|
|
|
|
|
|
Name of the schema which contains the table |
|
|
Table name |
|
|
The following constants are defined:
|
Examples
Considering the schema in the example for the ROWID_TO_EXTENDED function, you can use the following statement to find bad ROWIDs prior to conversion. This enables you to fix them beforehand.
SELECT ROWID, rowid_col FROM SCOTT.RIDS WHERE dbms_rowid.rowid_verify(rowid_col, NULL, NULL, 0) =1;