Why delete a where rowid=:1 go to index? [message #556237] |
Fri, 01 June 2012 02:20 data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
data:image/s3,"s3://crabby-images/78b42/78b42d6498b2d33b648800fd4901214cf970982a" alt="" |
zengmuansha
Messages: 26 Registered: April 2012
|
Junior Member |
|
|
SQL> create table a ( id number(5) not null,name varchar(35),create_time date);
Table created
Executed in 0.172 seconds
SQL> create index idx_a_id on a(id);
Index created
Executed in 0.032 seconds
SQL> exec dbms_stats.gather_table_stats(ownname=>'OSS03',tabname=>'A',cascade=>true);
PL/SQL procedure successfully completed
Executed in 0.125 seconds
SQL> set autot traceonly
SQL> delete a where rowid='AAAXXDFFESDFA';
----------------------------------------------------------
Plan hash value: 2233874139
-----------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------
| 0 | DELETE STATEMENT | | 1 | 25 | 0 (0)| 00:00:01 |
| 1 | DELETE | A | | | | |
|* 2 | INDEX FULL SCAN| IDX_A_ID | 1 | 25 | 0 (0)| 00:00:01 |
-----------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
2 - filter(ROWID=CHARTOROWID('AAAXXDFFESDFA'))
state info
----------------------------------------------------------
1 recursive calls
0 db block gets
1 consistent gets
0 physical reads
0 redo size
548 bytes sent via SQL*Net to client
483 bytes received via SQL*Net from client
4 SQL*Net roundtrips to/from client
2 sorts (memory)
0 sorts (disk)
0 rows processed
I find it is id column is not null ; Why the plan go to index?
|
|
|
|
|
|
|
|
Re: Why delete a where rowid=:1 go to index? [message #556269 is a reply to message #556263] |
Fri, 01 June 2012 05:50 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
John Watson
Messages: 8965 Registered: January 2010 Location: Global Village
|
Senior Member |
|
|
I get the expected result, when the table is empty and I use that impossible rowid:orcl> create table a ( id number(5) not null,name varchar(35),create_time date);
Table created.
orcl> create index idx_a_id on a(id);
Index created.
orcl> exec dbms_stats.gather_table_stats(ownname=>'SCOTT',tabname=>'A',cascade=>true)
PL/SQL procedure successfully completed.
orcl> set autot traceonly exp
orcl> delete a where rowid='AAAXXDFFESDFA';
0 rows deleted.
Execution Plan
----------------------------------------------------------
Plan hash value: 1898483634
------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
------------------------------------------------------------------------------------
| 0 | DELETE STATEMENT | | 1 | 25 | 1 (0)| 00:00:01 |
| 1 | DELETE | A | | | | |
|* 2 | TABLE ACCESS BY USER ROWID| A | 1 | 25 | 1 (0)| 00:00:01 |
------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
2 - access(CHARTOROWID('AAAXXDFFESDFA'))
Note
-----
- automatic DOP: skipped because of IO calibrate statistics are missing
orcl> This is 11.2.0.3.
|
|
|
|
Re: Why delete a where rowid=:1 go to index? [message #556273 is a reply to message #556263] |
Fri, 01 June 2012 06:10 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
data:image/s3,"s3://crabby-images/7dccb/7dccb0215d12eec7aff82634bff49c1f5d959d76" alt="" |
Michel Cadot
Messages: 68737 Registered: March 2007 Location: Saint-Maur, France, https...
|
Senior Member Account Moderator |
|
|
zengmuansha wrote on Fri, 01 June 2012 12:16Thanks,
Michel,your test is ok! but in my test,it go to the index when the table A have any data,can you tell the detail?
No, it does not got to the index.
The optimizer finds there is no data and stop analyzing keeping the current state of its analyze that you see but there is NO execution of this plan.
Regards
Michel
[Updated on: Fri, 01 June 2012 06:11] Report message to a moderator
|
|
|
|
|
|
Re: Why delete a where rowid=:1 go to index? [message #556286 is a reply to message #556284] |
Fri, 01 June 2012 07:47 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" |
data:image/s3,"s3://crabby-images/7dccb/7dccb0215d12eec7aff82634bff49c1f5d959d76" alt="" |
Michel Cadot
Messages: 68737 Registered: March 2007 Location: Saint-Maur, France, https...
|
Senior Member Account Moderator |
|
|
zengmuansha wrote on Fri, 01 June 2012 14:43In on 10g database analyze after insert data,that plan is going index!
Not in my case, copy and paste what you did and got as I did it.
Regards
Michel
|
|
|