news 2026/4/17 18:37:34

Python操作国产金仓数据库(KingbaseES)全流程:从环境搭建到实战应用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python操作国产金仓数据库(KingbaseES)全流程:从环境搭建到实战应用

安装必要的驱动和工具

KingbaseES提供了Python的适配驱动psycopg2kingbase-python。推荐使用psycopg2,因其兼容PostgreSQL协议且社区支持更广泛。通过pip安装:

pip install psycopg2-binary

若需使用官方驱动,需从KingbaseES官网下载kingbase-python驱动包,解压后运行:

python setup.py install

配置数据库连接参数

连接KingbaseES需要以下参数:主机地址、端口(默认54321)、数据库名、用户名、密码。示例配置字典:

db_config = { "host": "127.0.0.1", "port": "54321", "database": "test_db", "user": "system", "password": "your_password" }

建立数据库连接

使用psycopg2建立连接并创建游标:

import psycopg2 conn = psycopg2.connect(**db_config) cursor = conn.cursor()

执行简单查询验证连接:

cursor.execute("SELECT version();") print(cursor.fetchone())

执行CRUD操作

创建表

create_table_sql = """ CREATE TABLE IF NOT EXISTS users ( id SERIAL PRIMARY KEY, name VARCHAR(100), email VARCHAR(100) UNIQUE ) """ cursor.execute(create_table_sql) conn.commit()

插入数据

insert_sql = "INSERT INTO users (name, email) VALUES (%s, %s)" cursor.execute(insert_sql, ("张三", "zhangsan@example.com")) conn.commit()

批量插入

data = [("李四", "lisi@example.com"), ("王五", "wangwu@example.com")] cursor.executemany(insert_sql, data) conn.commit()

查询数据

cursor.execute("SELECT * FROM users WHERE name LIKE %s", ("张%",)) for row in cursor.fetchall(): print(row)

事务管理与异常处理

使用上下文管理器确保资源释放:

try: with conn.cursor() as cursor: cursor.execute("UPDATE users SET email=%s WHERE id=%s", ("new_email@example.com", 1)) conn.commit() except psycopg2.Error as e: conn.rollback() print(f"数据库错误: {e}") finally: if conn is not None: conn.close()

使用连接池提升性能

对于高频访问场景,建议使用psycopg2.pool

from psycopg2 import pool connection_pool = pool.SimpleConnectionPool( minconn=1, maxconn=10, **db_config )

获取连接示例:

conn = connection_pool.getconn() cursor = conn.cursor() cursor.execute("SELECT * FROM users") connection_pool.putconn(conn)

数据类型映射处理

KingbaseES与Python类型自动转换,特殊类型需注意:

  • BYTEA类型使用psycopg2.Binary包装
  • JSON类型直接传递Python字典

示例JSON操作:

import json cursor.execute("CREATE TABLE data (id SERIAL, info JSONB)") cursor.execute("INSERT INTO data (info) VALUES (%s)", (json.dumps({"key": "value"}),))

性能优化技巧

启用预处理语句:

cursor.execute("PREPARE user_query AS SELECT * FROM users WHERE id=$1") cursor.execute("EXECUTE user_query (1)", [1])

使用服务器端游标处理大数据集:

cursor = conn.cursor('server_side_cursor') cursor.itersize = 1000 # 每次获取1000条 cursor.execute("SELECT * FROM large_table") for row in cursor: process_row(row)

常用运维操作

备份数据库命令(需使用kb_dump工具):

kb_dump -h 127.0.0.1 -p 54321 -U system -F c -f backup.dump test_db

恢复数据库:

kb_restore -h 127.0.0.1 -p 54321 -U system -d test_db backup.dump

https://www.zhihu.com/zvideo/1992385373905654507/
https://www.zhihu.com/zvideo/1992385371703628812/
https://www.zhihu.com/zvideo/1992385370181092667/
https://www.zhihu.com/zvideo/1992385365475087279/
https://www.zhihu.com/zvideo/1992385364946600276/
https://www.zhihu.com/zvideo/1992385364212613491/
https://www.zhihu.com/zvideo/1992385364644619208/
https://www.zhihu.com/zvideo/1992385364011267670/
https://www.zhihu.com/zvideo/1992385361096250275/
https://www.zhihu.com/zvideo/1992385358852298426/
https://www.zhihu.com/zvideo/1992385355186446722/
https://www.zhihu.com/zvideo/1992385353466791686/
https://www.zhihu.com/zvideo/1992385348307788190/
https://www.zhihu.com/zvideo/1992385346567157317/
https://www.zhihu.com/zvideo/1992385341378798004/
https://www.zhihu.com/zvideo/1992385341085209633/
https://www.zhihu.com/zvideo/1992385340955177118/
https://www.zhihu.com/zvideo/1992385336144307915/
https://www.zhihu.com/zvideo/1992385335276115264/
https://www.zhihu.com/zvideo/1992385330452649728/
https://www.zhihu.com/zvideo/1992385328812664040/
https://www.zhihu.com/zvideo/1992385326325445146/
https://www.zhihu.com/zvideo/1992385325612414583/
https://www.zhihu.com/zvideo/1992385325381734592/
https://www.zhihu.com/zvideo/1992385324026982943/
https://www.zhihu.com/zvideo/1992385317852963935/
https://www.zhihu.com/zvideo/1992385310621984493/
https://www.zhihu.com/zvideo/1992385309548250555/
https://www.zhihu.com/zvideo/1992385307849553168/
https://www.zhihu.com/zvideo/1992385306482217062/
https://www.zhihu.com/zvideo/1992385305425250200/
https://www.zhihu.com/zvideo/1992385301088342975/
https://www.zhihu.com/zvideo/1992385298768863440/
https://www.zhihu.com/zvideo/1992385298605315785/
https://www.zhihu.com/zvideo/1992385291441440502/
https://www.zhihu.com/zvideo/1992385289184883945/
https://www.zhihu.com/zvideo/1992385285414220040/
https://www.zhihu.com/zvideo/1992385282188804226/
https://www.zhihu.com/zvideo/1992385280712402690/

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 5:24:52

JOIN之高级连接

目录 说明: 3 高级连接 4 员工数据库 4 使用员工数据库 5 按名字筛选 5 按名字、日期和时间筛选 6 显示每日总工时 说明: 1.数据库:MariaDB 2.数据库版本:10.11.14 3.SQL工具:DBeaver 4.本文来自与MariaDB官网的一片文章 5.操作系统:debian12 高级连接 探…

作者头像 李华
网站建设 2026/4/17 12:47:17

Dayjs常用操作使用

在前端开发中,经常会使用到时间组件,对于时间的处理,可以使用dayjs库,下面将一些dayjs常用的操作进行封装;1、时间对象与YYYYMMDD(年年年年月月日日)的互转时间对象转为“YYYYMMDD”export cons…

作者头像 李华
网站建设 2026/4/15 16:27:50

让 AI 自己打怪升级,Meta用Self-play RL把Coding推向超级智能

Meta FAIR & Meta TBD Lab&卡内基等:朝着“超级智能软件工程 Agent”迈出了第一步。 SSR(Self-play SWE-RL) 首次让大模型在“零人类标注”的情况下,仅靠自生成 Bug 自修复的左右互搏,就能在 SWE-bench 系列 …

作者头像 李华
网站建设 2026/4/17 12:58:27

[独家原创]CPO-VMD-KPCA-CPO-LSTM单变量时序预测 (单输入单输出) matlab代码

目录 1、代码简介 2、代码运行结果展示 3、代码获取 1、代码简介 [独家原创]CPO-VMD-KPCA-CPO-LSTM单变量时序预测 (单输入单输出) 基于冠豪猪算法优化变分模态分解-核主成分分析-冠豪猪算法-长短期记忆网络单变量时序预测 matlab代码 由于之前的图像分析太少,…

作者头像 李华