sqlalchemy 中缺少 zxJDBC 连接器(使用 DB2)

Missing zxJDBC connector in sqlalchemy (With DB2)

sqlalchemy + db2(远程服务器)应用程序遇到问题。

安装的依赖项:

这是连接片段:

self.__engine = create_engine(f'ibm_db_sa://{DB2_USER}:{DB2_PASSWD}@{DB2_INSTANCE}/{DB2_DB}')

看到下面的问题:

File "/db-query-service/query_executor/db_reader/db2_reader_with_query.py", line 19, in __init__
    self.__engine = create_engine(f'ibm_db_sa://{DB2_USER}:{DB2_PASSWD}@{DB2_INSTANCE}/{DB2_DB}')
  File "<string>", line 2, in create_engine
  File "/usr/local/lib/python3.8/site-packages/sqlalchemy/util/deprecations.py", line 298, in warned
    return fn(*args, **kwargs)
  File "/usr/local/lib/python3.8/site-packages/sqlalchemy/engine/create.py", line 522, in create_engine
    entrypoint = u._get_entrypoint()
  File "/usr/local/lib/python3.8/site-packages/sqlalchemy/engine/url.py", line 653, in _get_entrypoint
    cls = registry.load(name)
  File "/usr/local/lib/python3.8/site-packages/sqlalchemy/util/langhelpers.py", line 337, in load
    return impl.load()
  File "/usr/local/lib/python3.8/importlib/metadata.py", line 77, in load
    module = import_module(match.group('module'))
  File "/usr/local/lib/python3.8/importlib/__init__.py", line 127, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 1014, in _gcd_import
  File "<frozen importlib._bootstrap>", line 991, in _find_and_load
  File "<frozen importlib._bootstrap>", line 961, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
  File "<frozen importlib._bootstrap>", line 1014, in _gcd_import
  File "<frozen importlib._bootstrap>", line 991, in _find_and_load
  File "<frozen importlib._bootstrap>", line 975, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 671, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 783, in exec_module
  File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
  File "/usr/local/lib/python3.8/site-packages/ibm_db_sa/__init__.py", line 22, in <module>
    from . import ibm_db, pyodbc, base, zxjdbc
  File "/usr/local/lib/python3.8/site-packages/ibm_db_sa/zxjdbc.py", line 32, in <module>
    from sqlalchemy.connectors.zxJDBC import ZxJDBCConnector
ModuleNotFoundError: No module named 'sqlalchemy.connectors.zxJDBC'

问题:

参考文档:

暂时,您需要卸载 sqlalchemy 1.4.x 作为解决方法,然后安装当前的 sqlalchemy 1.3.x 版本。今天是 sqlalchemy 1.3.24,应该可以解决这个问题。

我希望这个问题最终会得到解决。

Link要发出的是here