python连接informix数据库

2 篇文章 0 订阅
2 篇文章 0 订阅

目前看到的集中方式  odbc  或  IfxPy  均需要配置环境变量,依赖系统的informix驱动,打包成的exe也不带驱动

    (mysql打的包带驱动可直接运行)

相对而言    IfxPy 更好点,只配置下 Informix Client SDK 即可

下载sdk,安装 IfxPy   见下文 链接1的博客(是linux的)

另外提供个windows64位的,如果需要linux自行去官网下载,需要注册账号

     官网下载地址:https://www-01.ibm.com/marketing/iwm/iwm/web/pickUrxNew.do?source=ifxdl

链接:https://pan.baidu.com/s/1G9tfSWEgBWR3QMFxdjJuRg 
提取码:xyln 
复制这段内容后打开百度网盘手机App,操作更方便哦

 

如果是windows只需要如下配置即可,配置环境变量  LD_LIBRARY_PATH

特别注意,位数要匹配,比如32位的 python 要用32位sdk.  64位同理

特别注意,gbase8s或者8t等,以下2个参数必须的,根据实际的数据库的格式来调整 

                     CLIENT_LOCALE=zh_cn.utf8;DB_LOCALE=zh_cn.GB18030-2000

代码如下:

import os
import sys
import IfxPy

#生成资源文件目录访问路径
import pyodbc


def resource_path(relative_path):
    if getattr(sys, 'frozen', False): #是否Bundle Resource
        base_path = sys._MEIPASS
    else:
        base_path = os.path.abspath(".")
    return os.path.join(base_path, relative_path)


SERVER = "实例名"
DATABASE="库名"
HOST="ip地址"
PORT = 端口号
UID = "用户名"
PWD = "密码"
connectStr = "PROTOCOL=onsoctcp;SERVICE=%s;UID=%s;PWD=%s;DATABASE=%s;HOST=%s;SERVER=%s;" \
             "CLIENT_LOCALE=zh_cn.utf8;DB_LOCALE=zh_cn.GB18030-2000"\
                 % (PORT,UID, PWD, DATABASE, HOST,SERVER )

connect=IfxPy.connect(connectStr, "", "")

# 查询数据
sql = "SELECT * FROM bblx"
data = ()
stmt = IfxPy.exec_immediate(connect, sql)
dictionary = IfxPy.fetch_assoc(stmt)

rc = 0
while dictionary != False:
    rc += 1
    print (dictionary)
    dictionary = IfxPy.fetch_assoc(stmt)

# 关闭连接
# Free up memory used by result and then stmt too
IfxPy.free_result(stmt)
IfxPy.free_stmt(stmt)
IfxPy.close(connect)

#打带console的包时,使窗口不会闪一下关闭
os.system("pause")

 

参考文章: 

链接1: https://www.cnblogs.com/yu121/p/14290846.html
链接2: https://github.com/OpenInformix/IfxPy/wiki

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值