python连接DM数据库

近期,随着工作需要,尝试使用python连接DM数据库。下面是工作过程中根据查找资料实现的过程,记录下来,提升下次快速搭建环境效率。

一、搭建基础环境

1、安装python软件和DM软件

(1)python官方下载地址:https://www.python.org/downloads/,然后按官方的手册安装python即可。

(2)dm官方下载地址:https://www.dameng.com/list_103.html ,然后可以按官方文档或我之前的文章安装DM数据库。两个软件都是普通的应用软件安装,此处就不再赘述。

二、安装DM DPI

使用python连接DM,一般是使用DM DPI组件完成,故此处以这个为例介绍。

可使用指令 pip show dmPython 查看dmPython版本,如下图

进入达梦数据库安装目录下的 dmPython 目录, pip install dmPython -timeout=1000

三、验证方式

#> python3 进入python环境

>>> import dmPython

>>> conn = dmPython.connect('SYSDBA', 'Dmsys_123', 'localhost:5236')

>>> dmPython.apilevel

执行命令 python setup.py install,安装成功后是如下效果图

四、编写测试程序,验证连接

  1. 编写程序

将如下代码拷贝生成一个python源码文件,如mytest.py(文件名可以随意改)。

coding:utf-8

import dmPython ##此处关键,引入程序包

try:

创建达梦数据库连接 对应的连接参数按实际情况调整

conn = dmPython.connect(user='sysdba', password='password', server='IP', port=5236)

创建数据库操作对象

cursor = conn.cursor()

try:

# 清空表,初始化测试环境

cursor.execute('delete from Table')

except (dmPython.Error, Exception) as err:

print(err)

try:

插入数据

cursor.execute("insert into DMHR.EMPLOYEE (EMPLOYEE_ID,EMPLOYEE_NAME,EMAIL,HIRE_DATE,JOB_ID) values(1157, '马云','888888888@qq.com','2023-05-12','42')")

print('python: insert success!')

# 更新数据

cursor.execute("update DMHR.EMPLOYEE set EMPLOYEE_NAME = '刘强东' where EMPLOYEE_ID = 1157")

print('python: update success!')

查询数据

cursor.execute("select name from DMHR.MYCOUNT")

res = cursor.fetchall()

for tmp in res:

for c1 in tmp:

print(c1)

print('python: select success!')

# 删除数据

cursor.execute("delete from DMHR.EMPLOYEE where EMPLOYEE_ID = 1157")

print('python: delete success!')

except (dmPython.Error, Exception) as err1:

print(err1)

conn.close()

except (dmPython.Error, Exception) as err:

print(err)

2、使用python mytest.py 验证返回情况

若正常输出结果,,表示成功完成。

注:可能遇到问题

1、若有类似提示setup.py:57: SyntaxWarning: invalid escape sequence '\s'

原因 :Python3将字符串文字解释为Unicode字符串,\视为转义的Unicode字符。

解决方案 :请将对应行中的"\"再转义一下,即改为"\\".

2、ModuleNotFoundError: No module named 'setuptools'

原因 :其实就是字面意思,当前系统中缺少 setuptools模块,故直接安装上该模块就可以了。

解决方案 :pip install setuptools 使用该指令安装对应模块

相关推荐
lili00122 小时前
2026 企业 AI 选型新范式:OpenRouter Fusion 证明多模型融合性价比远超单模型,企业该如何重构技术栈? - 微元算力(weytoken)
java·人工智能·python·重构·ai编程
Keano Reurink2 小时前
搜索API与GSC数据对比:发现数据盲区
数据库·python·数据挖掘
shushangyun_2 小时前
汽车服务行业B2B平台+AI解决方案哪家专业:2026年最新测评
java·运维·网络·数据库·人工智能·汽车
gCode Teacher 格码致知2 小时前
Javascript技术:CSS 中rem、vh 和 px各有其最佳适用场景-由Deepseek产生
开发语言·javascript·css
大黄说说2 小时前
深入理解 Go 协程 Goroutine:并发编程的核心精髓
java·数据库·python
超皮小龙猫2 小时前
c语言-1
c语言·开发语言
sulikey3 小时前
数据库系统概论4 - 更新与视图 期末速成课笔记
数据库·笔记·考试·期末速成·数据库系统概论
锋行天下3 小时前
数据库安全并发控制详解:乐观锁 vs 悲观锁 vs 原子操作
前端·数据库·后端
cd988803 小时前
2026年,电销机器人哪家强?
python
搏博3 小时前
多传感器融合基础之一图像空间(Image Space)全面解析
图像处理·python·图像空间·融合感知