python通过JayDeBeApi使用JDBC链接postgres

环境准备

获取JayDeBeApi
方法一:

pip install JayDeBeApi

方法二:

[admin@localhost ~]$ git clone https://github.com/baztian/jaydebeapi.git
Cloning into 'jaydebeapi'...
remote: Enumerating objects: 1710, done.
remote: Counting objects: 100% (123/123), done.
remote: Compressing objects: 100% (70/70), done.
remote: Total 1710 (delta 48), reused 90 (delta 27), pack-reused 1587
Receiving objects: 100% (1710/1710), 427.56 KiB | 452.00 KiB/s, done.
Resolving deltas: 100% (919/919), done.
[root@localhost jaydebeapi]# python3 setup.py install
running install
running bdist_egg
running egg_info
creating JayDeBeApi.egg-info
writing JayDeBeApi.egg-info/PKG-INFO
......

获取postgres JDBC驱动
https://jdbc.postgresql.org/download.html
我这里使用的是最新版:PostgreSQL JDBC 4.2 Driver, 42.3.3

测试数据

postgres=# \d
                  List of relations
 Schema |          Name           | Type  |  Owner
--------+-------------------------+-------+----------
 public | pg_stat_statements      | view  | postgres
 public | pg_stat_statements_info | view  | postgres
 public | student                 | table | postgres
 public | test_table              | table | postgres
(4 rows)

postgres=# select * from student;
 id |  name   | sex
----+---------+-----
  1 | Aspirin | M
  2 | Taxol   | F
(2 rows)

测试验证

[postgres@localhost ~]$ python3.6
Python 3.6.13 (default, Feb 18 2022, 03:06:10)
[GCC 7.3.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import jaydebeapi
>>> url = 'jdbc:postgresql://127.0.0.1:5432/postgres'
>>> user = 'postgres'
>>> password = 'xk.xmx190035'
>>> driver = 'org.postgresql.Driver'
>>> jarFile = './postgresql-42.3.3.jar'
>>> sqlStr = 'select * from student'
>>> conn = jaydebeapi.connect(driver, url, [user, password], jarFile)
>>> curs = conn.cursor()
>>> curs.execute(sqlStr)
>>> result = curs.fetchall()
>>> print(result)
[(1, 'Aspirin', 'M'), (2, 'Taxol', 'F')]
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏 克

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值