28. Troubleshooting Errors
Use the troubleshooting information documented in this section to address common errors that may appear while installing or using python-oracledb.
This chapter does not list all possible errors.
28.1. Installation Errors
You may encounter issues while installing python-oracledb. Review the
python-oracledb Installation Requirements. To understand the problem better, you can
display more output by using the -v option with the pip install command.
Review your output and logs.
If you need to modify your system version of Python and do not have the necessary access to modify it, then use:
python -m pip install oracledb --upgrade --user
Or you can use the venv module (built into Python 3.x).
This section covers some specific errors or problems that you may run into during python-oracledb installation, and possible solutions to resolve them.
If the installation problem still persists, then try to install python-oracledb using a different method. Google anything that looks like an error. Try some potential solutions.
28.1.1. “Not a supported wheel on this platform” Error
Cause: The python-oracledb installation failed with this error because
you may be using an older version of pip.
Action: Upgrade your pip version with the following command:
python -m pip install pip --upgrade --user
28.1.2. Network Connection Error
Cause: The python-oracledb installation failed because of a network connection error.
Action: To resolve this issue:
Check if you need to set the environment variables
http_proxyand/orhttps_proxy.Or try the following command:
python -m pip install --proxy=http://proxy.example.com:80 oracledb --upgrade
28.1.3. Upgrade to Latest Version Failed Without Any Errors
Cause: The upgrade to the latest python-oracledb version failed without any errors because the old version is still installed.
Action: To reinstall the latest version, try the following command:
python -m pip install oracledb --upgrade --force-reinstall
28.1.4. “No module named pip” Error
Cause: The python-oracledb installation failed with this error because the pip module that is built into Python may sometimes be removed by the OS.
Action: Instead, use the venv module (built into Python 3.x) or virtualenv module.
28.1.5. “fatal error: dpi.h: No such file or directory” Error
Cause: The python-oracledb installation from source code failed because a subdirectory called “odpi” may be missing.
Action: Check if your source installation has a subdirectory called “odpi” containing files. If this is missing, review the section on Building a python-oracledb package locally.
28.2. Warning Messages
Some warnings may appear while using python-oracledb in Thick or Thin mode.
28.2.1. Deprecated Python Version Warning
Warning: Python 3.6 is no longer supported by the Python core team.
Therefore, support for it is deprecated in python-oracledb and will be removed
in a future release. (A similar warning will also be displayed for Python
versions 3.7 and 3.8.)
Cause: import oracledb gives this warning because you are using a
version of Python that is longer maintained by the Python core team.
Action: You can either:
Upgrade your Python version to 3.9 or later.
Or you can temporarily suppress the warning by importing the warnings module and adding a call like
warnings.filterwarnings(action='ignore', module="oracledb")before importingoracledb.Install an older version of python-oracledb
28.3. Error Messages
While using python-oracledb in Thin or Thick mode, you may encounter errors. Some common DPI, DPY, and ORA errors are detailed in this section with information about the probable cause of the error, and the recommended action which may resolve the error.
If you have multiple versions of Python installed, ensure that you are using the correct python and pip (or python3 and pip3) executables.
28.3.1. DPI Error Messages
The error messages with prefix DPI are generated by the
ODPI-C code which is used by the
python-oracledb Thick mode.
Some common DPI error messages are discussed below.
28.3.1.1. DPI-1047
Message: DPI-1047: Oracle Client library cannot be loaded
Cause: The connection to Oracle Database failed because the Oracle Client library could not be loaded.
Action: Perform the following steps:
Review the features available in python-oracledb’s default Thin mode. If Thin mode suits your requirements, then remove the calls in your application to
oracledb.init_oracle_client()since this loads the Oracle Client library to enable Thick mode.On Windows and macOS, pass the
lib_dirlibrary directory parameter in youroracledb.init_oracle_client()call. The parameter should be the location of your Oracle Client libraries. Do not pass this parameter on Linux.Check if the Python process has permission to open the Oracle Client libraries. OS restrictions may prevent the opening of libraries installed in unsafe paths, such as from a user directory. On Linux you may need to install the Oracle Client libraries under a directory like
/optor/usr/local.Check if Python and your Oracle Client libraries are both 64-bit or both 32-bit. The
DPI-1047message will tell you whether the 64-bit or 32-bit Oracle Client is needed for your Python.If you are using Oracle Instant Client libraries (and not using a full Oracle Database installation or a full Oracle Instant Client installation (such as installed by Oracle’s GUI installer)), check whether the
ORACLE_HOMEenvironment variable is set. If it is, unset this variable.Set the environment variable
DPI_DEBUG_LEVELto 64 and restart python-oracledb. The trace messages will show how and where python-oracledb is looking for the Oracle Client libraries.At a Windows command prompt, this could be done with:
set DPI_DEBUG_LEVEL=64
On Linux and macOS, you might use:
export DPI_DEBUG_LEVEL=64
On Windows:
If you have a full database installation, ensure that this database is the currently configured database.
If you are not passing a library directory parameter to
oracledb.init_oracle_client(), then restart your command prompt and useset PATHto check if the environment variable has the correct Oracle Client listed before any other Oracle directories.Use the
DIRcommand to verify thatOCI.DLLexists in the directory passed tooracledb.init_oracle_client()or set inPATH.Check if the correct Windows Redistributables have been installed.
On Linux:
Check if the
LD_LIBRARY_PATHenvironment variable contains the Oracle Client library directory. Some environments such as web servers and daemons reset environment variables.If you are using Oracle Instant Client, a preferred alternative to
LD_LIBRARY_PATHis to ensure that a file in the/etc/ld.so.conf.ddirectory contains the path to the Instant Client directory, and then runldconfig.
28.3.1.2. DPI-1072
Message: DPI-1072: the Oracle Client library version is unsupported
Cause: The connection to Oracle Database failed because the Oracle Client library version used is not supported by python-oracledb Thick mode. The Thick mode needs Oracle Client library 11.2 or later.
Action: Review the Installation Requirements. You can either:
Follow the steps documented in DPI-1047 which may help.
Or may be use python-oracledb Thin mode which can be done by removing calls to
oracledb.init_oracle_client()from your code.
28.3.2. DPY Error Messages
The python-oracledb Thin mode code and python-oracledb Thick mode code
generates error messages with the prefix DPY.
Some common DPY error messages are discussed below.
28.3.2.1. DPY-3001
Message: DPY-3001: <feature> is only supported in python-oracledb <mode>
This error is diplayed when you attempt to use a feature in a python-oracledb driver mode that does not support it.
Some common examples are listed below.
28.3.2.1.1. Native Network Encryption and Data Integrity Error
Message: DPY-3001: Native Network Encryption and Data Integrity is only
supported in python-oracledb thick mode
Cause: The connection to Oracle Database failed because NNE or checksumming may be enabled in your Oracle Database and python-oracledb Thin mode does not support NNE.
Action: To verify if NNE or checksumming are enabled, you can use the following query:
SELECT network_service_banner FROM v$session_connect_info;
If NNE is enabled, then this query prints output that includes the available encryption service, the crypto-checksumming service, and the algorithms in use, such as:
NETWORK_SERVICE_BANNER
-------------------------------------------------------------------------------------
TCP/IP NT Protocol Adapter for Linux: Version 19.0.0.0.0 - Production
Encryption service for Linux: Version 19.0.1.0.0 - Production
AES256 Encryption service adapter for Linux: Version 19.0.1.0.0 - Production
Crypto-checksumming service for Linux: Version 19.0.1.0.0 - Production
SHA256 Crypto-checksumming service adapter for Linux: Version 19.0.1.0.0 - Production
If NNE is not enabled, then the query will only print the available encryption and crypto-checksumming services in the output. For example:
NETWORK_SERVICE_BANNER
-------------------------------------------------------------------------------------
TCP/IP NT Protocol Adapter for Linux: Version 19.0.0.0.0 - Production
Encryption service for Linux: Version 19.0.1.0.0 - Production
If NNE or checksumming are enabled, you can resolve this error by either:
Changing the architecture to use Transport Layer Security (TLS), which is supported in python-oracledb Thin and Thick modes. See Configuring Transport Layer Security Encryption.
See also
Oracle AI Database Security Guide for more information about Oracle Data Network Encryption and Integrity, and for information about configuring TLS network encryption.
28.3.2.1.2. Bequeath Error
Message: DPY-3001: Bequeath is only supported in python-oracledb thick
mode
Cause: The connection to Oracle Database failed because python-oracledb
Thin mode does not support bequeath connections or because the connection
string was not specified in the dsn parameter during connection creation.
Action: You can either:
Specify a valid connection string in the
dsnparameter during connection creation to continue using python-oracledb Thin mode.Or enable python-oracledb Thick mode since this mode can use bequeath connections. For Thick mode, you need to install Oracle Client libraries and call
oracledb.init_oracle_client()in your code.
28.3.2.2. DPY-3010
Message: DPY-3010: connections to this database server version are not
supported by python-oracledb in thin mode
Cause: The connection to Oracle Database with python-oracledb Thin mode failed because you are using Oracle Database version 11.2 or earlier. Using python-oracledb Thin mode, you can connect directly to Oracle Database 12.1 or later.
Action: You can either:
Enable python-oracledb Thick mode since this mode can connect to Oracle Database 9.2 or later. For Thick mode, you need to install Oracle Client libraries and call
oracledb.init_oracle_client()in your code.Upgrade Oracle Database to 12.1, or later, if you want to use python-oracledb Thin mode.
28.3.2.3. DPY-3015
Message: DPY-3015: password verifier type 0x939 is not supported by
python-oracledb in thin mode
Cause: The connection to Oracle Database with python-oracledb Thin mode failed because your database user account was only created with the Oracle Database 10G password verifier. Python-oracledb Thin mode supports password verifiers 11G and later.
Action: You can either:
Enable Thick mode since python-oracledb Thick mode supports password verifiers 10G and later.
Or you can:
Ensure that the database initialization parameter
sec_case_sensitive_logonis not FALSE. To check the value, connect as SYSDBA in SQL*Plus and run:show parameter sec_case_sensitive_logon
Note this parameter was removed in Oracle Database 21c so only step 2 is required for this, or subsequent, database versions.
Regenerate passwords for users who have old password verifiers. You can find such users with the query:
select username from dba_users where (password_versions = '10G ' or password_versions = '10G HTTP ') and username <> 'ANONYMOUS';
You can reset passwords for these users with commands like:
alter user x identified by y;
See also
Finding and Resetting User Passwords That Use the 10G Password Version for more information.
28.3.2.4. DPY-3029
Message: DPY-3029: "{name}" includes characters that are not allowed
Cause: Characters were used that are not supported by Oracle Net in the shown connection or configuration parameter or attribute.
Action: Values should be ASCII letters or digits. Allowed special
characters are '<>/,.:;-_$+*#&!%?@. Values should not contain enclosing
quotes. Also remove trailing commas and trailing backslashes.
28.3.2.5. DPY-4011
Message: DPY-4011: the database or network closed the connection
Cause: If this occurs when using an already opened connection, additional messages may indicate a reason.
If the error occurs when creating a connection or connection pool with python-oracledb 2 or earlier in Thin mode, the common cause is that Oracle Database has Native Network Encryption (NNE) enabled. Later versions of python-oracledb give the error DPY-3001 for this scenario. NNE and Oracle Net checksumming are only supported in python-oracledb Thick mode.
The error has been seen to occur if the database cannot handle the number of connections being opened.
Action: Review if NNE or checksumming are enabled. See DPY-3001 for solutions.
If connection load is an issue, then reconfigure the database or reduce connection load. Review the Connection Pool Sizing best practices and keep pool sizes small. When multiple python process need to open connection pools, then Database Resident Connection Pooling (DRCP) may be a solution.
If additional messages indicate a reason, follow their guidance.
28.3.2.6. DPY-4027
Message: DPY-4027: no configuration directory specified
Cause: The connection string specified in your connection
or pool creation dsn parameter was interpreted by python-oracledb to be a
TNS Alias which it needed to look up in a
tnsnames.ora file. However, python-oracledb did not know
where to find that file.
Action: You need to either tell python-oracledb where to find the tnsnames.ora file, or use a different connection string syntax. Perform one of the following:
Use the equivalent Easy Connect syntax or Connect Descriptor:
c = oracledb.connect(user="hr", password=userpw, dsn="localhost:1521/orclpdb")
Or:
c = oracledb.connect(user="hr", password=userpw, dsn="(DESCRIPTION=(ADDRESS=(...))")
Review the
oracledb.defaults.config_dirdocumentation for the heuristics used by python-oracledb to automatically locate tnsnames.ora. Ensure that your file is in an expected location, that the file is readable by Python, and that any necessary environment variables such asTNS_ADMINare accessible by the Python process.If you have problems with the heuristics, then you can explicitly specify the location of tnsnames.ora. For example, if the file is at
/opt/myconfigdir/tnsnames.ora, then:In python-oracledb’s default Thin mode, or when
oracledb.defaults.thick_mode_dsn_passthroughis False, you can use:c = oracledb.connect(user="hr", password=userpw, dsn="MYDB", config_dir="/opt/myconfigdir")
In python-oracledb’s Thick mode (which is the mode when your application calls
oracledb.init_oracle_client()), then you can use:oracledb.init_oracle_client(config_dir="/opt/myconfigdir") c = oracledb.connect(user="hr", password=userpw, dsn="MYDB")
28.3.3. ORA Error Messages
Some common ORA error messages are discussed below.
28.3.3.1. ORA-00933
Message: ORA-00933: SQL command not properly ended or
ORA-00933: unexpected keyword at or near <keyword_value>
Cause: Commonly this error occurs when the SQL statement passed to Oracle Database contains a trailing semicolon.
Action: If your code is like:
cursor.execute("select * from dept;")
Then remove the trailing semi-colon:
cursor.execute("select * from dept")
Note with Oracle Database version 23 this incorrect usage gives the message
ORA-03048: SQL reserved word ';' is not syntactically valid following
'select * from dept'.
See also
For other causes and solutions see Database Error Messages ORA-00933
28.3.3.2. ORA-01805
Message: ORA-01805: possible error in date/time operation
Cause: This error occurs in python-oracledb Thick mode when you use the TIMESTAMP WITH TIMEZONE data type, and use a named time zone offset, and the time zone file version of the client libraries and the database are different.
Action: Use the same time zone file version with the client libraries and the database, see Time Zone Files.
The use of a numeric time zone offset can be a workaround to the problem, but this can lead to undesired values being used when Daylight Savings Time begins or ends.
28.3.3.3. ORA-28009
Message: ORA-28009: connection as SYS should be as SYSDBA or SYSOPER
Cause: Commonly this error occurs when you try to create a connection pool
using oracledb.AUTH_MODE_SYSDBA in python-oracledb Thick mode.
Action: Use a standalone connection.
Alternatively, use python-oracledb Thin mode by removing all calls to
oracledb.init_oracle_client().
See also
For other causes and solutions see Database Error Messages ORA-28009