当前位置: 首页 > news >正文

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/

http://www.jsqmd.com/news/212268/

相关文章:

  • 《打破边界:云服务器的多元形态进化史》
  • 什么是路由监控组
  • 高通6490之完整26关节骨骼拓扑眼部跟踪集成
  • RAG技术详解:从原理到实践,让你轻松掌握大模型增强技术
  • B站用户弹幕情感可视化分析的python实现(源码+万字报告+讲解)(支持资料、图片参考_相关定制)
  • FastAPI 极简教程(偏实战,一篇搞定)
  • Linux用户、组创建
  • 中小微企业一体化管理系统横向对比:从CRM到生产的全链路能力拆解
  • K8S中使用 reloader 实现滚动升级
  • 大模型行业完全指南:从职位细分到产业生态,程序员必学收藏
  • 高通6490另类使用场景
  • 基于深度学习的智慧识花系统的设计与实现(源码+万字报告+讲解)(支持资料、图片参考_相关定制)
  • “ThreadLocal是什么?揭秘它的隐藏机制!(Java面试必看)”
  • 大模型风口已至:月薪30K+的AI岗批量诞生!收藏这份学习指南,小白也能快速入门
  • 值得收藏:AI产品经理转型大模型完全指南:技能评估、学习路径与实战资源
  • 高通6490之Snapdragon Spaces 集成指南(Unity 版)
  • 专科生必看!8个降AI率工具,高效避坑指南
  • STM32出现FLASH擦除失败异常现象分析及解决方法
  • Thinkphp和Laravel框架的火车票购票系统_33bx0nk0
  • 【故障排查】WPS/Word粘贴数学公式变图片?竟是格式在“搞鬼”
  • 高通6490之Snapdragon Spaces Unity 手部跟踪详细示例
  • AI大模型时代的人才画像:这些岗位核心能力你具备了吗?非常详细收藏我这一篇就够了
  • Dayjs常用操作使用
  • CMAKE指令集
  • 导师严选10个一键生成论文工具,本科生毕业论文轻松搞定!
  • 强烈安利MBA必用TOP8 AI论文工具测评
  • Thinkphp和Laravel框架的简历智能推荐系统_jw8dzu00
  • 2025年GEO优化实力排行榜,杭州爱搜索人工智能有限公司入选TOP5供应商
  • JOIN之高级连接
  • 限时公开!9款AI写论文神器,维普查重一把过无痕!