Как подключиться к базе данных из Jython

Я не могу подключиться к базе данных из моей программы Jython. Чистые Java-программы могут подключаться, и я могу подключаться к базе данных из Jython, но только с использованием моста JDBC-ODBC: «sun.jdbc.odbc.JdbcOdbcDriver». Если я использую собственный драйвер JDBC, моя программа завершается ошибкой с исключением «драйвер не найден».

Код:

import sys
from com.ziclix.python.sql import zxJDBC

connection1 = zxJDBC.connect('jdbc:odbc:test_odbc', 'postgres', 'postgres', 'sun.jdbc.odbc.JdbcOdbcDriver')
print "JDBC:ODBC connection set"
connection2 = zxJDBC.connect('jdbc:postgresql://127.0.0.1/test?stringtype=unspecified', 'postgres', 'postgres', 'org.postgresql.Driver')
print "JDBC native connection set"

Выход:

C:\tools\pyscripts\scripts\db_examples>jython --version
Jython 2.5b1 (trunk:5903:5905, Jan 9 2009, 16:01:29)
[Java HotSpot(TM) Client VM (Sun Microsystems Inc.)] on java1.6.0_11

C:\tools\pyscripts\scripts\db_examples>jython pg_test.py
JDBC:ODBC connection set
Traceback (most recent call last):
  File "pg_test.py", line 6, in <module>
    connection2 = zxJDBC.connect('jdbc:postgresql://127.0.0.1/test?stringtype=un
specified', 'postgres', 'postgres', 'org.postgresql.Driver')
zxJDBC.DatabaseError: driver [org.postgresql.Driver] not found

Я думаю, что мой CLASSPATH установлен правильно, в то время как собственные программы Java могут подключаться к этой базе данных с помощью собственного драйвера. Я обнаружил, что все драйверы JDBC имеют файлы .pkc в cachedir\packages.

Что я должен установить, чтобы получить соединение с базой данных?


person Michał Niklas    schedule 22.01.2009    source источник


Ответы (3)


сам себе отвечу:

В Jython 2.5b1 была ошибка: Jython имеет проблемы с динамической загрузкой классов при установке в загрузочный путь к классам

Я смог запустить свою программу, если я вызывал ее с флагом --verify.

Баг исчез в Jython 2.5b3

person Michał Niklas    schedule 23.01.2009

После борьбы с этим в течение дня я, наконец, нашел решение. Не беспокойтесь о zxJDBC, Class.forName, DriverManager и т. д. — просто создайте экземпляр драйвера напрямую:

import os
import sys
from java.util import Properties

# add the jar to your classpath, then import it
sys.path.append('/tmp/postgresql-8.4-701.jdbc4.jar')
import org.postgresql.Driver as Driver

props = Properties()
props.put('user', 'u')
props.put('password', 'p')

conn = Driver().connect('jdbc:postgresql://127.0.0.1', props)
person Greg    schedule 25.07.2013

У меня была та же проблема, и я не мог использовать флаг --verify (jython жаловался на неизвестный переключатель). Проблема исчезла волшебным образом, как только я настроил свою OS X Leopard Java для использования виртуальной машины 1.6 вместо 1.5.

person Jaanus    schedule 24.03.2009