Python驱动Ksycopg2连接和使用Kingbase:国产数据库实战指南

Python驱动Ksycopg2连接和使用Kingbase:国产数据库实战指南

引言

在国产数据库蓬勃发展的今天,KingbaseES作为国产数据库的佼佼者,凭借其高兼容性、高性能和高安全性,在金融、政府、能源等关键领域得到了广泛应用。本文将介绍如何通过Python的ksycopg2驱动连接并操作Kingbase数据库,从基础连接到高级操作全面掌握这一技术栈。

KingbaseES 数据库【系列篇章】

No.文章地址(点击进入)
1电科金仓KingbaseES数据库解析:国产数据库的崛起与技术创新
2KingBase数据库迁移利器:KDTS工具深度解析与实战指南
3KingBase数据库迁移利器:KDTS工具 MySQL数据迁移到KingbaseES实战
4电科金仓KingbaseES V9数据库:国产数据库的自主创新与行业实践深度解析
5KingbaseES客户端工具Ksql使用全指南:从安装到高级操作
6Spring JDBC与KingbaseES深度集成:构建高性能国产数据库应用实战
7深度解析:基于 ODBC连接 KingbaseES 数据库的完整操作与实践

一、ksycopg2驱动:连接Kingbase的桥梁

1.1 驱动架构深度剖析

ksycopg2 是 Python 编程语言的 KingbaseES 数据库适配器。
在Kingbase场景下展现出完美的兼容性。其底层采用C扩展实现,通过libpq库与数据库进行通信。该驱动完整实现了DB API 2.0规范,支持线程安全、异步通信、二进制协议传输等高级特性。

1.2 ksycopg2兼容Python版本信息

数据库版本包默认支持 Python 2.7 和 Python 3.5 的 64 位 ksycopg2 驱动,如需其他版本,可在官网下载(点击进入)的接口模块中获取更多版本支持。

驱动支持 Python 2.7 及 Python 3.5 至 3.10 版本,具体兼容性如下表所示:

在这里插入图片描述

1.3 环境配置要求

  1. 安装与驱动对应版本的数据库,且数据库连接可用
  2. 确保 Ksycopg2 支持开发环境:
    Linux:x86_64、arm、loongarch、mips、sw
    Windows:提供64位支持
  3. 编译器:
    Linux:仅支持依赖 glibc 的编译的 Python。
    Windows:依赖 msvc120 的运行时库。
  4. Python 环境:
    见目录1.2中的版本兼容表

满足以上条件后,可通过已发布版本的数据库安装包、官网下载接口、或联系技服人员获取对应版本架构的 Ksycopg2 驱动

官网下载接口路径(点击进入)展示:

版本列表选取对应的版本文件

在这里插入图片描述

选择接口驱动

在这里插入图片描述

二、安装部署驱动

检测系统架构及 Python 版本信息,选择适配的 Ksycopg2 数据库驱动

查看 Python 版本

$ python -V Python 3.5.6 

当前环境使用的是 Python3.5,若对应架构是 x86_64,则应该选用 x86 架构的 Python3.5 版本的 Ksycopg2 驱动包安装

解压适用于对应架构和 Python 版本的 Ksycopg2 驱动包后,Linux 环境下 Python 3.5 版本的驱动目录结构如下:

在这里插入图片描述


_ksycopg 开头的这个库就是 Python 驱动,后缀为 .py 的文件是 Ksycopg2 驱动提供的可拓展的 Python 文件,包括了一些游标工厂、批量执行、连接池等功能。

将 ksycopg2 这个文件夹拷贝到对应 Python 安装目录下的 site-packages 路径下(site-packages 路径是 Python 默认加载模块的搜索路径),以下是模块路径示例:

在这里插入图片描述


安装完成后,在Python命令行中执行import psycopg2命令,检查是否出现错误提示。

在确认驱动包使用无误的前提,若导入模块仍然报错

错误信息

Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/home/python/py-3.5/lib/python3.5/site-packages/ksycopg2/__init__.py", line 51, in <module> from ksycopg2._ksycopg import ( # noqa ImportError: libkci.so.5: cannot open shared object file: No such file or directory 

原因:这是因为 Ksycopg2 驱动以动态库形式存在,且依赖 Libkci 库。当 Python 加载 Ksycopg2 时,只能识别到主库本身,而未能检测到其依赖库,因此产生了错误提示

解决:建议通过配置环境变量 LD_LIBRARY_PATH 来设置 Linux 系统的默认库搜索路径。该路径可指定 Psycopg2 驱动包自带的依赖库,若无依赖库也可配置其他任意依赖库路径

配置(Ksycopg2 驱动包内一般会提供依赖库):

export LD_LIBRARY_PATH=/home/python/py-3.5/lib/python3.5/site-packages/ksycopg2:$LD_LIBRARY_PATH 

在Windows环境下,系统通常会自动识别site-packages/ksycopg2目录中的依赖库,无需额外配置环境变量。但需要注意的是,必须安装MSVC120(VS2013)运行时库,否则将无法加载驱动程序

无报错的话,表示 Ksycopg2 驱动成功导入

三、程序源码开发

3.1 创建文件夹

创建测试程序文件夹 test_ksycopg2,新建源码文件 test_ksycopg2.py,目录示例如下:

test_ksycopg2 └── test_ksycopg2.py 

3.2 开发源程序 test_ksycopg2.py

导入Ksycopg2

import ksycopg2 

使用 ksycopg2.connect() 创建连接,并连接到数据库:

conn = ksycopg2.connect("dbname=dbname user=user password=pwd host=host port=port") 例: conn = ksycopg2.connect("dbname=test user=system password=123456 host=127.0.0.1 port=54321")

创建连接后,使用刚刚创建的连接新建一个 Cursor 对象,用于操作数据库:

cur = conn.cursor()

使用 cur.execute() 执行 SQL 语句:

# 创建新表 cur.execute('drop table if exists test_ksy') cur.execute('create table test_ksy(id integer, name TEXT)')# 插入数据 cur.execute("insert into test_ksy values(%s, %s)",(1,"John")) cur.execute("insert into test_ksy values(%s, %s)",(2,'中文测试文字')) cur.execute("insert into test_ksy values(%s, %s)",(3,'!@#¥%……'))

插入成功后,使用 cur.execute() 执行查询,接着使用 cur.fetchall() 获取结果集并打印:

# 执行查询,并获取结果集 cur.execute("select * from test_ksy") rows = cur.fetchall()# 打印结果集print("result for query:")for row in rows:print("\t", row)

查询结束后,需要关闭游标及连接。

完整示例,示例使用 Python 语法:

# -*- coding: utf-8 -*-import ksycopg2 database ="TEST" user ="SYSTEM" password ="123456" host ="127.0.0.1" port ="54321"try: conn = ksycopg2.connect("dbname={} user={} password={} host={} port={}".format(database, user, password, host, port)) cur = conn.cursor() cur.execute('drop table if exists test_ksy') cur.execute('create table test_ksy(id integer, name TEXT)') cur.execute("insert into test_ksy values(%s, %s)",(1,"John")) cur.execute("insert into test_ksy values(%s, %s)",(2,'中文测试文字')) cur.execute("insert into test_ksy values(%s, %s)",(3,'!@#¥%……')) cur.execute("select * from test_ksy") rows = cur.fetchall()print(type(rows),type(rows[0]))print("result for query:")for row in rows:print("\t", row) cur.close() conn.close()except Exception as e:print(e) exit()

四、运行程序

4.1 执行

编写好测试相关代码后,使用 Python 执行即可:

python test_ksycopg2.py 

输出如下所示:

<class'list'><class'tuple'> result for query:(1,'John')(2,'中文测试文字')(3,'!@#¥%……')

4.2 bug 处理流程

  1. 驱动包 SSL 库与系统环境的 SSL 库冲突
    原因:系统环境中存在依赖库版本过高的问题,或者应用程序在运行时错误地加载了系统环境的SSL库。
    解决:执行ldd _ksycopg命令检查驱动依赖关系,确保应用程序运行时正确加载驱动包提供的SSL库。若仍出现SSL相关报错,说明当前环境无法使用驱动包自带的SSL库,此时请联系技术支持获取包含静态依赖SSL库的Ksycopg2驱动包以解决冲突问题。
  2. Ksycopg2 加载失败
    报错信息:No module named ‘ksycopg2._ksycopg’
    原因:驱动包可能因架构不匹配、Python版本冲突或安装路径错误导致无法被Python识别。
    解决:请确保安装与系统架构及Python版本匹配的驱动包。若驱动包已正确安装但仍出现问题,可能是Python未能识别Ksycopg2模块,此时可通过强制设置Python模块搜索路径来解决:
>>>import sys >>> sys.path.insert(0,"Ksycopg2 驱动包的父目录")

五、结语

数据库技术的发展永无止境,Kingbase作为国产数据库的代表,正在书写着属于中国数据库的辉煌篇章。掌握其与Python的集成技术,不仅是技术能力的体现,更是参与国产化替代战略的重要实践。本文介绍了Python驱动Ksycopg2连接和使用Kingbase,后续博主会继续介绍其他语言的连接与数据库的开发。

Read more

CustomTkinter终极指南:5分钟创建现代化Python桌面应用

CustomTkinter终极指南:5分钟创建现代化Python桌面应用 【免费下载链接】CustomTkinterA modern and customizable python UI-library based on Tkinter 项目地址: https://gitcode.com/gh_mirrors/cu/CustomTkinter CustomTkinter是一个基于Python Tkinter的现代化UI库,为传统Tkinter注入了全新的生命力。它提供了一系列美观、现代化且完全可定制的组件,支持自动适配系统外观模式和高DPI缩放,让Python桌面应用开发变得简单而优雅。 为什么选择CustomTkinter?🚀 在Python GUI开发领域,传统Tkinter界面陈旧,而PyQt等库学习曲线陡峭。CustomTkinter完美解决了这一痛点——它保留了Tkinter的简单语法,同时提供了媲美现代桌面应用的视觉效果。 深色主题的复杂应用界面,包含侧边栏、选项卡、文本框、滑块、按钮等多种组件 浅色主题的复杂应用界面,展示了CustomTkinter在ma

By Ne0inhk
Python快速落地的临床知识问答与检索项目(2025年9月教学配置部分)

Python快速落地的临床知识问答与检索项目(2025年9月教学配置部分)

项目概述与技术选型 本项目定位为临床辅助决策支持工具,而非替代临床诊断的独立系统,旨在解决医疗行业两大核心痛点:一是医学知识更新速率加快,2025 年临床指南年均更新量较 2020 年增长 47%,传统知识管理方式难以同步;二是科室规范呈现碎片化分布,不同院区、亚专科的诊疗流程存在差异,导致知识检索效率低下。技术路线采用 RAG 知识库 + ChatFlow 多轮对话 + 工具节点对接 的三层架构,通过整合指南文献、临床路径和院内 SOP 文档,满足门诊快速问诊、病房随访问答及科室知识库精准检索需求,最终实现医疗信息可及性提升 30%、基层医生决策效率提高 25% 的核心价值目标[1]。 技术栈选型分析 1. 大语言模型:领域专精与多模态融合 临床知识问答核心模型需兼顾专业性与部署灵活性。2025 年主流选型包括: * Chimed - GPT:基于 Ziya - V2 架构,通过预训练、

By Ne0inhk
Python中一切皆对象:深入理解Python的对象模型

Python中一切皆对象:深入理解Python的对象模型

Python中一切皆对象:深入理解Python的对象模型 * 什么是"一切皆对象"? * Python对象的类型层次 * 1. 内置类型对象 * 2. 函数对象 * 3. 类对象和实例对象 * 4. 模块对象 * 对象行为的统一性 * 特殊方法:对象行为的背后 * 对象模型的实际应用 * 性能考虑 * 总结 Python以其"一切皆对象"的设计哲学而闻名,这种设计为语言带来了极大的灵活性和一致性。本文将深入探讨Python的对象模型,解释为什么说"Python中一切皆对象",并通过实例展示这一特性如何影响我们的编程方式。 什么是"一切皆对象"? 在Python中,从简单的数字、字符串到复杂的函数、类甚至模块,所有这些都是对象。这意味着它们都有: 1. 身份(identity):对象在内存中的唯一地址,可通过id()函数获取 2.

By Ne0inhk
Python 识别携程中文验证码(95%正确率)并自动登陆携程+图灵图像验证码识别平台

Python 识别携程中文验证码(95%正确率)并自动登陆携程+图灵图像验证码识别平台

这两天有一个业务需求,需要登陆不同的携程账号获取订单信息,但是由于携程有验证码检测机制,而且是个中文验证码比较难识别,试了几家人工打码平台,要么贵,要么延时高,要么没办法24小时运行。最后总算让我找到一个可以通过机器识别出来的API接口,准确率超级高而且延迟只有0.03s左右。(不算上传图片的时间) 首先看一下携程验证码长啥样。。。 携程验证码分为小图和大图部分,小图部分如下:      大图部分的样子如下:   原理是要先识别小图的文字,然后点击到大图对应文字的正确位置。 这里借助了图灵验证码识别平台,不是人工打码的,所以识别很快,准确率也挺高: 在线图片验证码识别平台-图像验证码识别打码平台-图片验证码打码平台-图灵 官网网址:http://fdyscloud.com.cn 进入图灵验证码识别平台,点击中文类型:   可以看到图灵识别平台提供的几个中文识别模型。我们这里需要用到的就是 中文通用类型 和 图片识别类型9。分别点进去,会告诉你对应的模型ID和接口的调用方式。  我们也可以直接在网站上先上传图片测试一下该模型的识别效果,如下图:  可以看到效果是

By Ne0inhk