2. API: Defaults Object
This object contains attributes that can be used to adjust the behavior of the python-oracledb driver.
All attributes are supported in Thin and Thick modes, subject to noted details.
An example of changing a default value is:
import oracledb
oracledb.defaults.fetch_lobs = False # return LOBs directly as strings or bytes
2.1. Defaults Attributes
- defaults.arraysize
The default value for
Cursor.arraysize. This is a query tuning attribute, see Tuning Fetch Performance.This attribute has an initial value of 100.
- defaults.config_dir
The directory in which optional configuration files such as
tnsnames.orawill be read in python-oracledb Thin mode. This attribute takes its initial value from the environment variableTNS_ADMIN.This attribute is not used by the python-oracledb Thick mode: the usual Oracle Client search path behavior for configuration files is followed, see Optional Oracle Net Configuration Files.
- defaults.driver_name
The default value that represents the driver used by the client to connect to Oracle Database. This is the value used in the
CLIENT_DRIVERcolumn of theV$SESSION_CONNECT_INFOview.This attribute has an initial value of None. It is used as required in python-oracledb Thick and Thin mode.
In python-oracledb Thick mode, this attribute is used if the
driver_nameparameter is not specified inoracledb.init_oracle_client(). In Thin mode, this attribute is used if thedriver_nameparameter is not specified inoracledb.connect(),oracledb.connect_async(),oracledb.create_pool(), ororacledb.create_pool_async(). If the value of this attribute is None, the value set when connecting in python-oracledb Thick mode is like “python-oracledb thk : <version>” and in Thin mode is like “python-oracledb thn : <version>”. See Other python-oracledb Thick Mode Initialization.Added in version 2.5.0.
- defaults.fetch_decimals
Identifies whether numbers should be fetched as decimal.Decimal values. This can help avoid issues with converting numbers from Oracle Database’s decimal format to Python’s binary format.
An output type handler such as previously required in cx_Oracle (see return_numbers_as_decimals.py) can alternatively be used to adjust the returned type. If a type handler exists and returns a variable (that is,
cursor.var(...)), then that return variable is used. If the type handler returns None, then the value oforacledb.defaults.fetch_decimalsis used to determine whether to returndecimal.Decimalvalues.This attribute has an initial value of False.
- defaults.fetch_lobs
When the value of this attribute is True, then queries to LOB columns return LOB locators. When the value of this attribute is False, then CLOBs and NCLOBs are fetched as strings, and BLOBs are fetched as bytes. If LOBs are larger than 1 GB, then this attribute should be set to True and the LOBs should be streamed. See Using CLOB and BLOB Data.
An output type handler such as the one previously required in cx_Oracle (see return_lobs_as_strings.py) can alternatively be used to adjust the returned type. If a type handler exists and returns a variable (that is, cursor.var(…)), then that return variable is used. If the type handler returns None, then the value of
oracledb.defaults.fetch_lobsis used.The value of
oracledb.defaults.fetch_lobsdoes not affect LOBs returned as OUT binds.This attribute has an initial value of True.
- defaults.machine
The default value that represents the machine name of the client connecting to Oracle Database. This is the value used in the
MACHINEcolumn of theV$SESSIONview.This attribute takes the host name where the application is running as its initial value.
This attribute is only used in python-oracledb Thin mode.
Added in version 2.5.0.
- defaults.osuser
The default value that represents the operating system user that initiates the database connection. This is the value used in the
OSUSERcolumn of theV$SESSIONview.This attribute takes the login name of the user as its initial value.
This attribute is only used in python-oracledb Thin mode.
Added in version 2.5.0.
- defaults.prefetchrows
The default value for
Cursor.prefetchrows. This is a query tuning attribute, see Tuning Fetch Performance.This attribute has an initial value of 2.
- defaults.program
The default value that represents the program name connected to the database. This is the value used in the
PROGRAMcolumn of theV$SESSIONview.This attribute has an initial value that is populated by sys.executable.
This attribute is only used in python-oracledb Thin mode.
Added in version 2.5.0.
- defaults.stmtcachesize
The default value for
Connection.stmtcachesizeandConnectionPool.stmtcachesize. This is a tuning attribute, see Statement Caching.This attribute has an initial value of 20.
- defaults.terminal
The default value that represents the terminal identifier from which the connection originates. This is the value used in the
TERMINALcolumn of theV$SESSIONview.This attribute has an initial value of “unknown”.
This attribute is only used in python-oracledb Thin mode.
Added in version 2.5.0.