cx_Oracle is a Python extension module that enables access to Oracle Database and conforms to the Python database API 2.0 specifications with a considerable number of additions and a couple of exclusions. The time data type is not supported by Oracle and is therefore not implemented. The method cursor.nextset() is not implemented either as the DB API specification assumes an implementation of cursors that does not fit well with Oracle's implementation of cursors and implicit results. See the method cursor.getimplicitresults() for more information.
See PEP 249 for more information on the Python database API specification. See the documentation for a complete description of the module's capabilities.
cx_Oracle is licensed under a BSD license which you can find here.
cx_Oracle has been tested with Python version 2.7, and with versions 3.4 and higher. You can use cx_Oracle with Oracle 11.2, 12.1 and 12.2 client libraries, allowing connection to multiple Oracle Database versions. Oracle's standard client-server version interoperability allows connection to both older and newer databases, for example Oracle 11.2 client libraries can connect to Oracle Database 10.2 or later.
Please note that an Oracle client (or server) installation is required in order to use cx_Oracle. If you do not require the tools that come with a full client installation, it is recommended to install the Instant Client. which is far easier to install.
Issues and questions can be raised with the cx_Oracle community on GitHub or on the mailing list.
See the cx_Oracle Documentation and Release Notes.
The simplest way to install cx_Oracle 6 Beta is with pip:
python -m pip install cx_Oracle --pre
If a binary wheel package is not available on PyPI for your platform, the source package will be used.
If you prefer, the source package can be downloaded manually from PyPI and extracted, after which the following commands should be run:
python setup.py build
python setup.py install
Note that if you download a source zip file directly from GitHub that you will also need to download an ODPI-C source zip file and extract it inside a directory called "odpi".
After cx_Oracle is installed, Oracle client libraries must also be installed and configured. If you need the libraries, you can download and unzip the Oracle Instant Client 'Basic' package for your platform and set PATH, LD_LIBRARY_PATH, or similar platform-specific library path loading environment. See the installation notes for ODPI-C for help with installing and configuring an Oracle client.
Versions 11.2, 12.1 and 12.2 of the Oracle Client libraries on Linux, Windows and macOS are supported. Users have also reported success with other platforms.
from __future__ import print_function   # needed for Python 2.x
import cx_Oracle
# connect via SQL*Net string or by each segment in a separate argument
#connection = cx_Oracle.connect("user/password@TNS")
connection = cx_Oracle.connect("user", "password", "TNS")
cursor = connection.cursor()
cursor.execute("""
        select Col1, Col2, Col3
        from SomeTable
        where Col4 = :arg_1
          and Col5 between :arg_2 and :arg_3""",
        arg_1 = "VALUE",
        arg_2 = 5,
        arg_3 = 15)
for column_1, column_2, column_3 in cursor:
    print("Values:", column_1, column_2, column_3)For more examples, please see the test suite and the samples. You can also look at the scripts in the cx_OracleTools and the modules in the cx_PyOracleLib projects.
- 
Easily installed from PyPI. 
- 
Support for Python 2 and 3. 
- 
Support for Oracle Client 11.2, 12.1 and 12.2. Oracle's standard cross-version interoperability, allows easy upgrades and connectivity to different Oracle Database versions. 
- 
Connect to Oracle Database 9.2, 10, 11 or 12 (depending on the Oracle Client version used). 
- 
SQL and PL/SQL Execution, with full support for OCI features like statement caching and statement caching auto-tuning. Oracle OCI (which is the database access layer used by cx_Oracle) has significant optimizations, including compressed fetch, pre-fetching, client and server result set caching, and statement caching. cx_Oracle applications can additionally make full use of PL/SQL to keep business logic near the data in the database, where it can be processed without having to ship large volumes of data to the application. 
- 
Full use of Oracle Network Service infrastructure, including encrypted network traffic and security features. 
- 
Extensive Oracle data type support, including large object support (CLOB and BLOB). 
- 
Direct binding to SQL objects. One great use case is binding Python objects to Oracle Spatial SDO objects. 
- 
Array operations for efficient INSERT and UPDATEs. 
- 
Array row counts and batch error handling for array operations. 
- 
Fetching of large result sets. 
- 
REF CURSOR support. 
- 
Support for scrollable cursors. Go back and forth through your query results. 
- 
Fetch PL/SQL Implicit Results. Easily return query results from PL/SQL. 
- 
Row Prefetching. Efficient use of the network. 
- 
Client Result Caching. Improve performance of frequently executed look-up statements. 
- 
Support for Advanced Queuing. Use database notifications to build micro-service applications. 
- 
Continuous Query Notification. Get notified when data changes. 
- 
Support for Edition Based Redefinition. Easily switch applications to use updated PL/SQL logic. 
- 
Support for setting application context during the creation of a connection, making application metadata more accessible to the database, including in LOGON triggers. 
- 
End-to-end monitoring and tracing. 
- 
Transaction Management. 
- 
Session Pooling. 
- 
Database Resident Connection Pooling (DRCP). 
- 
Privileged Connections. 
- 
External Authentication. 
- 
Database startup and shutdown. 
- 
Oracle Database High Availability Features, such as FAN notifications and Transaction Guard support.