python使用jdbc连接phoenix

本文介绍了如何在Python中使用JayDeBeApi库通过jdbc连接到Phoenix。由于线程安全问题,建议在一个线程中创建连接,其他线程通过队列进行交互。注意,64位整型查询结果为Java的Long对象,需要手动处理转换。
摘要由CSDN通过智能技术生成


lib使用jaydebeapi,依赖jpype

链接:https://pypi.python.org/pypi/JayDeBeApi/


代码里面有说明 threadsafety = 1,我试了跨线程访问创建的连接对象,进程直接挂了,后来改成使用一个线程专门做jdbc,其他线程用队列交互。


64位整形查询出来的结果是一个java对象,<jpype._jclass.java.lang.Long object at 0xxxxxxxx>,jaydebeapi默认没有转换,需要自己在__init__.py添加

_to_bigint = _java_to_py('longValue')

同时在_DEFAULT_CONVERTERS里面添加BIGINT转换:

_DEFAULT_CONVERTERS = {
    # see
    # http://download.oracle.com/javase/6/docs/api/java/sql/Types.html
    # for possible keys
    'TIMESTAMP': _to_datetime,
    'TIME': _to_time,
    'DATE': _to_date,
    'BINARY': _to
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值