Python防止重复资源的链接mysql方法

配置连接池

配置连接池

POOL = PooledDB(

creator=pymysql,

maxconnections=5, # 连接池最大连接数

mincached=1, # 初始化时连接池至少创建的空闲连接数

maxcached=2, # 连接池最大空闲连接数

host="localhost",

port=3306,

user="root",

password="123456",

database="test_db",

charset="utf8mb4",

cursorclass=pymysql.cursors.DictCursor)

安装

PooledDB 是 DBUtils 库中实现数据库连接池的核心类,作用是复用数据库连接(避免频繁创建 / 关闭连接的性能损耗),尤其适合高并发 / 高频数据库操作的场景。下面从核心原理、完整使用示例、参数详解、最佳实践四部分讲解如何正确使用 PooledDB。

一、核心原理

连接池的本质是「预先创建一批数据库连接,存放在池中,当需要操作数据库时从池里取连接,用完后放回池里(不真正关闭)」,核心优势:

减少连接创建 / 销毁的开销(MySQL 创建连接的耗时远高于 SQL 执行);

控制最大连接数,避免数据库因连接过多崩溃;

自动管理连接的空闲 / 复用状态。

安装 PyMySQL

#pip install pymysql

#pip install DBUtils

报错

Traceback (most recent call last):

File "E:\demo\app4.py", line 3, in

from DBUtils.PooledDB import PooledDB # 需安装:pip install DBUtils

^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

ModuleNotFoundError: No module named 'DBUtils'

既然终端显示 Requirement already satisfied: DBUtils in f:\tools\python\lib\site-packages (3.1.2)(DBUtils 已安装),但代码仍报 ModuleNotFoundError: No module named 'DBUtils',核心原因是运行代码的 Python 环境,和安装 DBUtils 的环境不一致(比如用了虚拟环境、IDE 解释器配置错误、多个 Python 版本冲突)。

下面按「优先级从高到低」给出解决方案,确保彻底匹配环境:

bash 复制代码
# 替换为你打印的Python路径(示例)
F:\tools\python\python.exe -m pip list | findstr DBUtils
# 卸载
F:\tools\python\python.exe -m pip uninstall -y DBUtils
# 方案1:阿里云源(稳定性高)
F:\tools\python\python.exe -m pip install DBUtils==3.1.2 -i https://mirrors.aliyun.com/pypi/simple/
# 方案2:豆瓣源
F:\tools\python\python.exe -m pip install DBUtils==3.1.2 -i https://pypi.doubanio.com/simple/
# 方案3:中科大源
F:\tools\python\python.exe -m pip install DBUtils==3.1.2 -i https://pypi.mirrors.ustc.edu.cn/simple/
# 方案4:官方源(无镜像限制,可能慢但稳定)
F:\tools\python\python.exe -m pip install DBUtils==3.1.2 --trusted-host pypi.org --trusted-host files.pythonhosted.org
相关推荐
AI玫瑰助手14 分钟前
Python函数:默认参数的定义与注意事项
开发语言·python·信息可视化
weixin_4684668518 分钟前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
油炸自行车23 分钟前
Claude Code 错误:API Error: 400 Failed to deserialize the JSON body into the
开发语言·javascript·json·trae·claude code·api error 400
肩上风骋30 分钟前
C++14特性
开发语言·c++·c++14特性
小糖学代码37 分钟前
LLM系列:环境搭建:5.Python-dotenv 环境变量管理
人工智能·python·深度学习·神经网络
智慧物业老杨1 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
橙橙笔记1 小时前
Python的学习第一部分
python·学习
JAVA社区2 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展
唐青枫2 小时前
MySQL EXISTS 详解:存在性判断、NOT EXISTS 与实战示例
sql·mysql
弥树子2 小时前
踩坑记录:服务器内网调用接口,真实请求URL与官方公开URL不一致问题排查
开发语言·php