Guidelines for capturing section explain information
The section explain functionality captures (either directly or via tooling) explain information about a statement using only the contents of the runtime section. The section explain is similar to the functionality provided by the db2expln command, but the section explain gives a level of detail approaching that which is provided by the explain facility.
By explaining a statement using the contents of the runtime section, you can obtain information and diagnostics about what will actually be run (or was run, if the section was captured after execution), as opposed to issuing an EXPLAIN statement which might produce a different access plan (for example, in the case of dynamic SQL, the statistics might have been updated since the last execution of the statement resulting in a different access plan being chosen when the EXPLAIN statement compiles the statement being explained).
The section explain interfaces will populate the explain tables with information that is similar to what is produced by an EXPLAIN statement. However, there are some differences. After the data has been written to the explain tables, it may be processed by any of the existing explain tools you want to use (for example, the db2exfmt command).
Section explain interfaces
- EXPLAIN_FROM_ACTIVITY
- Takes application ID, activity ID, uow ID, and activity event monitor name as input. The procedure searches for the section corresponding to this activity in the activity event monitor (an SQL activity is a specific execution of a section). A section explain using this interface contains section actuals because a specific execution of the section is being performed.
- EXPLAIN_FROM_CATALOG
- Takes package name, package schema, unique ID, and section number as input. The procedure searches the catalog tables for the specific section.
- EXPLAIN_FROM_DATA
- Takes executable ID, section, and statement text as input.
- EXPLAIN_FROM_SECTION
- Takes executable ID and location as input, where location is specified
by using one of the following:
- In-memory package cache
- Package cache event monitor name
An executable ID uniquely and consistently identifies a section. The executable ID is an opaque, binary token generated at the data server for each section that has been executed. The executable ID is used as input to query monitoring data for the section, and to perform a section explain.
In each case, the procedure performs an explain, using the information contained in the identified runtime section, and writes the explain information to the explain tables identified by an explain_schema input parameter. It is the responsibility of the caller to perform a commit after invoking the procedure.