news 2026/6/10 11:39:22

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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 版本冲突)。
下面按「优先级从高到低」给出解决方案,确保彻底匹配环境:

# 替换为你打印的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 pipinstallDBUtils==3.1.2 -i https://mirrors.aliyun.com/pypi/simple/# 方案2:豆瓣源F:\tools\python\python.exe -m pipinstallDBUtils==3.1.2 -i https://pypi.doubanio.com/simple/# 方案3:中科大源F:\tools\python\python.exe -m pipinstallDBUtils==3.1.2 -i https://pypi.mirrors.ustc.edu.cn/simple/# 方案4:官方源(无镜像限制,可能慢但稳定)F:\tools\python\python.exe -m pipinstallDBUtils==3.1.2 --trusted-host pypi.org --trusted-host files.pythonhosted.org
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/2 18:03:02

新手入门 Java:第一个程序 HelloWorld 详解

作为一名刚接触 Java 的大学生,相信很多小伙伴和我一样,从HelloWorld开启 Java 编程之旅。这个看似简单的程序,却包含了 Java 的基础语法和运行逻辑,今天就带大家一步步拆解,搞定 Java 第一个程序!一、准备…

作者头像 李华
网站建设 2026/6/10 11:42:24

实际项目开发应用--485通信

一、485通信波特率的选择 长距离485Modbus通信时,波特率设置“小点更好” ——核心原则是“优先保证通信稳定性,再兼顾效率”,高波特率会加剧信号衰减、抗干扰能力下降,反而容易出现丢包、误码;低波特率虽通信速度慢&a…

作者头像 李华
网站建设 2026/6/10 11:08:57

【JavaSE】十八、URL HTTP请求格式 常见报头 状态码 会话保持

文章目录Ⅰ. URLⅡ. 报文格式Ⅲ. HTTP 请求方法💥 GET 和 POST 的区别Ⅳ. HTTP 常见报头Ⅴ. HTTP 状态码Ⅵ. 会话保持一、Cookie二、Session三、两者区别四、理解 cookie、session、token 三者的区别Ⅰ. URL 统一资源描述定位符 URL(Uniform Resource L…

作者头像 李华
网站建设 2026/6/10 2:43:34

车间每天报喜不报忧,直到真 OEE 摆上墙,谁都装不下去!

目录 一、车间数据造假,到底有多日常? 1. 停机时间“自动消失” 2. 产量“向上取整”,报废“向下取整” 3. 点检表天天签,谁也没看过 二、为什么大家宁愿造假,也不愿报真实? 1. 指标只考结果&#xf…

作者头像 李华
网站建设 2026/6/9 20:59:06

python3.7-python3.12通过whl安装dlib

1、安装Cmakepip install cmake2、安装boostpip install cmake3、通过whl文件安装dlib下载链接中包括python3.7-python3.12版本对应的dlib库例如我的python版本是3.12,在.whl下载路径下,输入以下指令安装pip install dlib-19.24.2-cp312-cp312-win_amd64…

作者头像 李华
网站建设 2026/6/10 11:45:41

合并区间(二维vector使用,多维vector使用默认sort)

注意点&#xff1a; 1.sort自带的比较函数是支持多维数组比较的&#xff0c;使用的是字典序比较&#xff1b; 2.对于多维的vector&#xff0c;可以使用back&#xff0c;front,at等函数 比较例子&#xff1a; 二维 vector 示例 vector<vector<int>> v {{2,5},{1,3}…

作者头像 李华