Suppose I have a table and an index on it
original simple table A
------------------------
rowid | id name
123 | 1 A
124 | 4 G
125 | 2 R
126 | 3 P
index on A.id
-------------
id rowid
1 123
2 125
3 126
4 124
At this point, I execute this DML statement
UPDATE A SET id = 5 WHERE id = 4
What exactly happens when this statement is executed?
a)
BEGIN
go to index
search for `id == 4` (B tree index generally)
find that `rowid = 124`
go to that location
update id in the table
come back (? I am not sure)
update the index
END
b)
BEGIN
go to index
search for `id == 4` (B tree index generally)
update the id value in index
find that `rowid = 124`
go to that location
update id in the table
END
c) Something else entirely happens
As this might be dependent on the database itself, how does it happen in Oracle?