PyMySQL与MySQL连接池相关的知识点

2024-04-16 09:32

本文主要是介绍PyMySQL与MySQL连接池相关的知识点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 常规用法

如果使用PyMySQL,常见的方法如下

connection = pymysql.connect(host="localhost",port=3306,database="forest",user="root",password="123456"
)with connection.cursor() as cursor:print(cursor)cursor.execute("select count(*) from user")data = cursor.fetchall()print(data,)

其中名词的解释如下:

  • Connection
    Representation of a socket with a mysql server.
    The proper way to get an instance of this class is to call connect().Establish a connection to the MySQL database
  • Cursor
    This is the object used to interact with the database.
    Do not create an instance of a Cursor yourself. Call connections.Connection.cursor().

2. 连接池用法

连接池指的是应用和数据库的连接池,理论上是应用提前准备好(如启动时)几个和数据库连接好的连接,一直供应用使用,直到应用关闭,省去每次查询时重新连接上数据库和关闭数据库连接的时间。

其中连接池指的即是多个 connection的连接池

具体实践可以使用 DBUtilsPyMySQL构造连接池

  1. DBUtils User’s Guide, https://webwareforpython.github.io/DBUtils/main.html
  2. https://github.com/WebwareForPython/DBUtils
2.1 如何查询到连接池

连接上MySQL,通过命令show full processlist即可查询当前连接上MySQL的连接(或即socket连接)

如下,即为通过 Navicat for MySQL 连接上查询出的结果
在这里插入图片描述

2.2 构造连接池

通过 DBUtilsPyMySQL构造连接池的代码如下

import time
import pymysql
from dbutils.pooled_db import PooledDBpool = PooledDB(pymysql,3,  # 默认初始化好3个连接host="localhost",port=3306,database="forest",user="root",password="123456")
connection = pool.connection()if __name__ == '__main__':print("sleep 30 ...")time.sleep(30)

Navicat for MySQL 连接上查询出的结果如下(在sleep结束之前),可以看到time=3,即该连接活跃的时间长度
在这里插入图片描述

这篇关于PyMySQL与MySQL连接池相关的知识点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/908418

相关文章

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

MySQL 衍生表(Derived Tables)的使用

《MySQL衍生表(DerivedTables)的使用》本文主要介绍了MySQL衍生表(DerivedTables)的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录一、衍生表简介1.1 衍生表基本用法1.2 自定义列名1.3 衍生表的局限在SQL的查询语句select

MySQL 横向衍生表(Lateral Derived Tables)的实现

《MySQL横向衍生表(LateralDerivedTables)的实现》横向衍生表适用于在需要通过子查询获取中间结果集的场景,相对于普通衍生表,横向衍生表可以引用在其之前出现过的表名,本文就来... 目录一、横向衍生表用法示例1.1 用法示例1.2 使用建议前面我们介绍过mysql中的衍生表(From子句

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二: