OracleX $ tables-Part1-Wheredotheygettheirdatafrom? ByTanelPoderPostedonJanuary10, 2014It 'slong-timepublicknowledgethatX $ fixedtablesinOraclearejust "windows" then oracle 'smemory. Sowheneveryouqueryan
Oracle X $ tables-Part 1-Where do they get their data from? By Tanel Poder Posted on January 10,201 4 It's long-time public knowledge that X $ fixed tables in Oracle are just "windows" into Oracle's memory. So whenever you query
Oracle X $ tables-Part 1-Where do they get their data from?
By Tanel PoderPosted on January 10,201 4
It's long-time public knowledge that X $ fixed tables in Oracle are just "windows" into Oracle's memory. so whenever you query an X $ table, the fixed table rowsource function in your SQL execution plan will just read some memory structure, parse its output and show you the results in tabular form. this is correct, but not the whole truth.
Check this example. Let's query the X $ KSUSE table, which is used by V $ SESSION:
SQL> SELECT addr, indx, ksuudnam FROM x$ksuse WHERE rownum <= 5;ADDR INDX KSUUDNAM-------- ---------- ------------------------------391513C4 1 SYS3914E710 2 SYS3914BA5C 3 SYS39148DA8 4 SYS391460F4 5 SYS
Now let's check in which Oracle memory region this memory address resides (SGA, PGA, UGA etc ). i'm using my scriptfcha for this (Find CHunk Address ). you shoshould probably not run this script in busy production systems as it uses the potentially dangerous X $ KSMSP fixed table:
SQL> @fcha 391513C4Find in which heap (UGA, PGA or Shared Pool) the memory address 391513C4 resides...WARNING!!! This script will query X$KSMSP, which will cause heavy shared pool latch contentionin systems under load and with large shared pool. This may even completely hangyour instance until the query has finished! You probably do not want to run this in production!Press ENTER to continue, CTRL+C to cancel...LOC KSMCHPTR KSMCHIDX KSMCHDUR KSMCHCOM KSMCHSIZ KSMCHCLS KSMCHTYP KSMCHPAR--- -------- ---------- ---------- ---------------- ---------- -------- ---------- --------SGA 39034000 1 1 permanent memor 3977316 perm 0 00SQL>
OK, these X $ KSUSE (V $ SESSION) records reside in a permanent allocation in SGA and my X $ query apparently just parsed & presented the information from there.
Now, let's query something else, for example the "Soviet Union" view X $ KCCCP:
SQL> SELECT addr, indx, inst_id, cptno FROM x$kcccp WHERE rownum <= 5;ADDR INDX INST_ID CPTNO-------- ---------- ---------- ----------F692347C 0 1 1F692347C 1 1 2F692347C 2 1 3F692347C 3 1 4F692347C 4 1 5
OK, let's see where do these records reside:
SQL> @fcha F692347CFind in which heap (UGA, PGA or Shared Pool) the memory address F692347C resides...WARNING!!! This script will query X$KSMSP, which will cause heavy shared pool latch contentionin systems under load and with large shared pool. This may even completely hangyour instance until the query has finished! You probably do not want to run this in production!Press ENTER to continue, CTRL+C to cancel...LOC KSMCHPTR KSMCHIDX KSMCHDUR KSMCHCOM KSMCHSIZ KSMCHCLS KSMCHTYP KSMCHPAR--- -------- ---------- ---------- ---------------- ---------- -------- ---------- --------UGA F6922EE8 kxsFrame4kPage 4124 freeabl 0 00SQL>
Wow, why does the X $ KCCCP data reside in my session's UGA? This is where the extra complication (and sophistication) of X $ fixed tables comes into play!
Some X $ tables do not simply read whatever is in some memory location, but they have helper functions associated with them (something like fixed packages that the ASM instance uses internally ). so, whenever you query this X $, then first a helper function is called, which will retrieve the source data from whereever it needs, then copies it to your UGA in the format corresponding to this X $ andThenThe normal X $ memory location parsing & presentation code kicks in.
If you trace what the X $ KCCCP access does-you 'd see a bunchControl file parallel readWait events every time you query the X $ table (to retrieve the checkpoint progress records ). so this X $ is not doing just a passive read only presentation of some memory structure (array ). the helper function will first do some real work, allocates some runtime memory for the session (the kxsFrame4kPage chunk in UGA) and copies the results of its work to this UGA area-so that the X $ array & offset parsing code can read and present it back to the query engine.
In other words, the ADDR column in X $ tables does not necessarily show whereSource dataIt shows ultimately lives, but just where the final array that got parsed for presentation happened to be. Sometimes the parsed data structureIsThe ultimate source where it comes from, sometimes a helper function needs to do a bunch of work (like taking latches and walking linked lists for X $ KSMSP or even doing physical disk reads from controlfiles for X $ KCCCP access ).
And more, let's run the same query against X $ KCCCP twice:
SQL> SELECT addr, indx, inst_id, cptno FROM x$kcccp WHERE rownum <= 5;ADDR INDX INST_ID CPTNO-------- ---------- ---------- ----------F69254B4 0 1 1F69254B4 1 1 2F69254B4 2 1 3F69254B4 3 1 4F69254B4 4 1 5
And once more:
SQL> SELECT addr, indx, inst_id, cptno FROM x$kcccp WHERE rownum <= 5;ADDR INDX INST_ID CPTNO-------- ---------- ---------- ----------F692B508 0 1 1F692B508 1 1 2F692B508 2 1 3F692B508 3 1 4F692B508 4 1 5
See how the ADDR column has changed between executions even though we are querying the same data! This is not because the controlfiles or the source data have somehow relocated. it's just that the temporary cursor execution scratch area, where the final data structure was put for presentation (kxsFrame4kPage chunk in UGA ), just happened to be allocated from different locations for the two different executions.
There may be exceptions, but as long as the ADDR resides in SGA, I 'd say it's the actual location of where the data lives-but when it's in UGA/PGA, itMayBe just the temporary cursor scratch area and the source data was taken from somewhere else (especially when the ADDR constantly changes or alternates between 2-3 different variants when running your X $ query ). note that there are X $ tables which intentionally read data from arrays in your UGA (the actual source data lives in the UGA or PGA itself), but more about that in the future.
Related Posts
- Where is LOB data stored?
- Profiling trace files with preprocessor external tables in 11g and some parallel execution hacking
- Oracle In-Memory Column Store Internals-Part 1-Which SIMD extensions are getting...
- Oracle Exadata Performance series-Part 1: shocould I use Hugepages on Linux Database Nodes?
- When do Oracle Parallel Execution Slaves issue buffered physical reads-Part 2?