The JayDeBeApi module allows you to connect from Python code to databases using Java JDBC. It provides a Python DB-API v2.0 to that database.
It works on ordinary Python (cPython) using the JPype Java integration or on Jython to make use of the Java JDBC driver.
In contrast to zxJDBC from the Jython project JayDeBeApi let's you access a database with Jython AND Python with only minor code modifications. JayDeBeApi's future goal is to provide a unique and fast interface to different types of JDBC-Drivers through a flexible plug-in mechanism.
You can get and install JayDeBeApi with pip
$ pip install JayDeBeApi
If you want to install JayDeBeApi in Jython make sure to have pip or EasyInstall available for it.
Or you can get a copy of the source by cloning from the JayDeBeApi github project and install with
$ python setup.py install
or if you are using Jython use
$ jython setup.py install
It has been tested with Jython 2.7-rc1.
If you are using cPython ensure that you have installed JPype properly. It has been tested with JPype1 0.5.7. Older JPype installations may cause problems.
Basically you just import the jaydebeapi
Python module and execute
the connect
method. This gives you a DB-API conform connection to
the database.
The first argument to connect
is the name of the Java driver
class. Then you can supply a single argument or a sequence of
arguments that are internally passed to the Java
DriverManager.getConnection
method. Usually this is the JDBC
connection URL. See the Javadoc of DriverManager
class for
details.
The next parameter to connect
is optional and specifies the
jar-Files of the driver if your classpath isn't set up sufficiently
yet. The classpath set in CLASSPATH
environment variable will be
honored. See the documentation of your Java runtime environment.
Here is an example:
>>> import jaydebeapi
>>> conn = jaydebeapi.connect('org.hsqldb.jdbcDriver',
... ['jdbc:hsqldb:mem:.', 'SA', ''],
... '/path/to/hsqldb.jar',)
>>> curs = conn.cursor()
>>> curs.execute('create table CUSTOMER'
... '("CUST_ID" INTEGER not null,'
... ' "NAME" VARCHAR not null,'
... ' primary key ("CUST_ID"))'
... )
>>> curs.execute("insert into CUSTOMER values (1, 'John')")
>>> curs.execute("select * from CUSTOMER")
>>> curs.fetchall()
[(1, u'John')]
Also it's possible to make connections using attributes dict. It allows to pass additional parameters to connection in more comfort way than in connection string.
Also it helps with parameters which cannot be passed via url, for example accessToken
for MS SQL server
(see documentation).
You can read more about this in java docs
Here's an example of connecting to MS SQL Server with Windows domain credentials:
>>> import jaydebeapi
>>> connection_parameters = {
... "user": "DomainUserName",
... "password": "DomainPassW0RD!",
... "domain": "DOMAINNAME"
... }
>>> conn = jaydebeapi.connect('net.sourceforge.jtds.jdbc.Driver',
... ('jdbc:jtds:sqlserver://server:1433/database', connection_parameters),
... '/path/to/jar/jtds-1.2.5.jar',)
>>> conn.setAutoCommit(False)
>>> curs = conn.cursor()
>>> curs.execute('CREATE TABLE Users ('
... 'id INT PRIMARY KEY NOT NULL AUTO_INCREMENT, '
... 'Name VARCHAR(200), '
... 'Location VARCHAR(200) '
... ');')
>>> curs.execute("insert into Users (Name, Location) values ('John', 'North Pole')")
>>> conn.commit()
>>>
>>> curs.execute("select * from Users")
>>> curs.fetchall()
[(1, u'John', u'North Pole')]
If you're having trouble getting this work check if your JAVA_HOME
environmentvariable is set correctly. For example I have to set it on
my Ubuntu machine like this
$ JAVA_HOME=/usr/lib/jvm/java-6-openjdk python
In theory every database with a suitable JDBC driver should work. It is confirmed to work with the following databases:
- SQLite
- Hypersonic SQL (HSQLDB)
- IBM DB2
- IBM DB2 for mainframes
- Oracle
- Teradata DB
- Netezza
- Mimer DB
- Microsoft SQL Server
- MySQL
- PostgreSQL
- many more...
Please submit bugs and patches. All contributors will be acknowledged. Thanks!
JayDeBeApi is released under the GNU Lesser General Public license
(LGPL). See the file COPYING
and COPYING.LESSER
in the
distribution for details.
- Next version - unreleased
- 0.2.1 - 2016-10-16 - Connection with properties support.
- 0.2.0 - 2015-04-26
- Python 3 support (requires JPype1 >= 0.6.0).
- 0.1.6 - 2015-04-10
- Fix Jython handling of Java exceptions that don't subclass python Exception
- Enrich exceptions with message from java SQLExceptions
- Be more specific about DB API exceptions: Distinguish DatabaseError and InterfaceError.
- Fix typo LONGNARCHAR vs LONGVARCHAR (thanks @datdo for reporting #4)
- 0.1.5 - 2015-03-02
- Add version number to module.
- Improve robustness of java to python type conversion.
- Support Time type.
- Add DB-API compliant exception handling.
- Minor documentation improvements.
- Some development related changes (Host project at github, use Travis CI, use JPype1 for tests).
- 0.1.4 - 2013-10-29
- More convenient way to setup Java classpath. Important note
check the changes to the
connect
method and adapt your code. - Honor
CLASSPATH
if used in JPype mode. - Set
.rowcount
properly. - Changed signature of
.setoutputsize()
to be DB-API compliant.
- More convenient way to setup Java classpath. Important note
check the changes to the
- 0.1.3 - 2011-01-27
- Fixed DB-API violation: Use
curs.execute('foo ?', (bar, baz))
instead ofcurs.execute('foo ?', bar, baz)
. - Free resources after
executemany
call. - Improved type handling. Initial support for BLOB columns.
- Fixed DB-API violation: Use
- 0.1.2 - 2011-01-25
easy_install JayDeBeApi
should really work.
- 0.1.1 - 2010-12-12
- Fixed bug #688290 "NULL values with converters error on fetch".
- Fixed bug #684909 "Selecting ROWIDs errors out on fetch".
- 0.1 - 2010-08-10
- Initial release.
- Extract Java calls to separate Java methods to increase performance.
- Check if https://code.launchpad.net/dbapi-compliance can help making JayDeBeApi more DB-API compliant.
- Test it on different databases and provide a flexible db specific pluign mechanism.
- SQLAlchemy modules (separate project)