How to set the log level from a Session variable Initialization
block
As we know it is normal to set the log level non-zero for a particular user when we wish to debug problems. However sometimes it is inconvenient to go into each user’s properties in the Admin tool and update the log level. So I am showing a method which allows the log level to be set for all users via a session initialization
block. This is particularly useful for anyone wanting an alternative way to set the log level.
The screen shots shown are using the OBIEE 11g SampleApp demo but are applicable
to any environment.
Open the appropriate rpd in on-line mode and navigate to Manage Variables.
Select Session Initialization Blocks, right click in the white space and create a New Initialization
Block.
I called the Initialization
block Set_Loglevel .
Now click on ‘Edit Data Source’ to enter the SQL.
Chose the ‘Use OBI EE Server’ option for the SQL. This means that
the SQL provided must use tables which have been defined in the Physical layer
of the RPD, and whilst there is no need to provide a connection pool you must
work in On-Line mode.
The SQL can access any of the RPD tables and is purely used to return a value
of 2. The ‘Test’ button confirms that the SQL is valid.
Next, click on the ‘Edit Data Target’ button to add the LOGLEVEL
variable to the initialization
block.
Check the ‘Enable any user to set the value’ option so that this
will work for any user.
Click OK and the following message will display as LOGLEVEL is a system session
variable:
Click ‘Yes’.
Click ‘OK’ to save the Initialization
block. Then check in the
On-LIne changes.
To test that LOGLEVEL has been set, log in to OBIEE using an administrative
login (e.g. weblogic) and reload server metadata, either from the Analysis
editor or from Administration > Reload Files and Metadata link. Run a query
then navigate to Administration > Manage Sessions and click ‘View
Log’ for the query just issued (which should be approximately the last
in the list). A log file should exist and with LOGLEVEL set to 2 should include
both logical and physical sql. If more diagnostic information is required then
set LOGLEVEL to a higher value.
If logging is required only for a particular analysis then an alternative
method can be used directly from the Analysis editor.
Edit the analysis for which debugging is required and click on the Advanced
tab. Scroll down to the Advanced SQL clauses section and enter the following
in the Prefix box:
SET VARIABLE LOGLEVEL = 2;
Click the ‘Apply SQL’ button.
The SET VARIABLE statement will now prefix the Analysis’s logical SQL.
So that any time this analysis is run it will produce a log.
You can find information about training for Oracle BI EE products here or
in the OU Learning Paths.
Please send me an email at
[email protected] if you have any further
questions.
About the Author:
Gerry Langton started at Siebel Systems in 1999 working as a technical instructor
teaching both Siebel application development and also Siebel Analytics (which
subsequently became Oracle BI EE). From 2006 Gerry has worked as Senior Principal
Instructor within Oracle University specialising in Oracle BI EE, Oracle BI
Publisher and Oracle Data Warehouse development for BI.