sqlalchemy连接mysql数据库

news2024/11/6 7:05:55

create_engine() 是 SQLAlchemy 中用于创建数据库连接的函数,它接受多个参数来配置连接池、日志输出等方面。你提到的 create_engine(DATABASE_URI, echo=True, pool_size=5, max_overflow=2, pool_timeout=30) 中的各个参数的含义如下:

1. DATABASE_URI

  • 意义: 这是连接数据库的 URI 字符串,通常包括数据库的类型(如 postgresql://mysql://),用户名、密码、主机、端口、数据库名称等信息。
  • 示例: 'postgresql://user:password@localhost/mydatabase'

2. echo=True

  • 意义: 控制 SQLAlchemy 是否输出 SQL 执行的日志。

    • True:会打印所有执行的 SQL 语句(包括参数化查询的 SQL),以及数据库返回的结果。
    • False:关闭 SQL 日志输出(默认)。
  • 用途: 开发调试时,启用 echo=True 可以帮助你查看生成的 SQL 查询,检查是否与预期一致。

    示例:

    engine = create_engine(DATABASE_URI, echo=True)
    

3. pool_size=5

  • 意义: 设置连接池的大小,即连接池中保持的数据库连接数的数量。

    • 连接池是 SQLAlchemy 为了高效地管理数据库连接而实现的一种机制,避免每次都要重新建立连接。
    • pool_size=5 表示池中最多可以同时存在 5 个连接。
  • 用途: 适用于高并发的应用,允许多个数据库连接并发执行查询。调整 pool_size 可以控制连接池的大小,以应对不同的负载需求。

    示例:

    engine = create_engine(DATABASE_URI, pool_size=5)
    

4. max_overflow=2

  • 意义: 设置连接池可以额外创建的连接数,超过 pool_size 的连接数。也就是,当连接池中的连接都被占用时,最多可以创建 max_overflow 个额外的连接。

    • max_overflow=2 表示池子最多可以超出 pool_size 2 个额外连接(在高峰时创建更多临时连接以处理并发请求)。
    • 如果请求的连接数超过池大小 + max_overflow,会导致连接请求被阻塞,直到有连接释放。
  • 用途: 当负载非常高时,可以设置较大的 max_overflow 来增加连接池的最大容量,以避免连接请求被阻塞。

    示例:

    engine = create_engine(DATABASE_URI, max_overflow=2)
    

5. pool_timeout=30

  • 意义: 设置获取连接池连接的超时时间(秒)。

    • pool_timeout=30 表示如果连接池中没有空闲连接,SQLAlchemy 会等待 30 秒,如果在这段时间内没有获得连接,则会抛出超时错误。
    • 该参数有助于避免在高负载情况下等待连接池超时。
  • 用途: 如果你预计在高并发情况下,数据库连接池可能会暂时被占满,设置合适的 pool_timeout 可以避免请求长时间阻塞。

    示例:

    engine = create_engine(DATABASE_URI, pool_timeout=30)
    

综合示例

假设我们需要创建一个 PostgreSQL 数据库的引擎,连接池大小为 5,最多可以超出 2 个连接,连接获取超时时间为 30 秒,并启用 SQL 调试日志输出。代码如下:

from sqlalchemy import create_engine

DATABASE_URI = 'postgresql://user:password@localhost/mydatabase'

engine = create_engine(
    DATABASE_URI,
    echo=True,               # 启用 SQL 日志输出
    pool_size=5,             # 连接池大小 5
    max_overflow=2,          # 超过池大小的最大额外连接数 2
    pool_timeout=30          # 获取连接时的最大等待时间 30 秒
)

总结:

  • DATABASE_URI: 数据库连接的 URL。
  • echo: 是否打印 SQL 语句。
  • pool_size: 连接池的大小,控制池中保持的最大连接数。
  • max_overflow: 连接池可以超出的最大连接数。
  • pool_timeout: 获取连接池连接的最大等待时间。

这些参数帮助你灵活地配置数据库连接池,从而优化数据库访问性能,尤其是在高并发环境下。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2234129.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux 28】应用层协议 - HTTPS

文章目录 🌈 一、HTTPS 相关概念⭐ 1. 什么是 HTTPS⭐ 2. 加密 & 解密 & 密钥⭐ 3. 常见的加密方式⭐ 4. 数据摘要 & 数据指纹⭐ 5. 初识数字签名 🌈 二、HTTPS 的加密方案探究⭐ 1. 方案一:只使用对称加密⭐ 2. 方案二&#xff…

qt QFileDialog详解

1、概述 QFileDialog是Qt框架中的一个对话框类,用于提供一个标准的文件选择对话框。它允许用户浏览文件系统,选择一个或多个文件或目录,以及指定文件名。QFileDialog支持本地文件系统和远程文件系统(如通过FTP或SFTP访问的文件系…

C语言不同基本数据类型占用字节大小和取值范围

具体请前往:C语言各种基本数据类型字节大小和取值范围

Vue3:新特性详解

本文目录: 1.特性函数setup2.Ref 语法3.Reactive 函数4.Vue3 生命周期5.侦测变化 - watch6.Vue3的模块化开发7.弹窗类组件优化:Teleport8.异步组件优化:Suspense9.全局API优化 1.特性函数setup 1、setup函数是处于 生命周期函数 beforeCreate…

Linux scp命令 | 菜鸟教程-从本地复制到远程/从远程复制到本地

目录 Linux scp命令 语法 实例 1、从本地复制到远程 2、从远程复制到本地 说明 文章来源:Linux scp命令 | 菜鸟教程 Linux scp命令 nux scp 命令用于 Linux 之间复制文件和目录。 scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远…

计算机毕业设计Python+大模型膳食推荐系统 知识图谱 面向慢性病群体的膳食推荐系统 健康食谱推荐系统 机器学习 深度学习 Python爬虫 大数据毕业设计

温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…

大数据集群中实用的三个脚本文件解析与应用

目录 一、jps - cluster.sh 脚本文件 (一)背景与功能 (二)使用方法 二、集群文件分发脚本 xsync.sh (一)背景与问题 (二)功能与实现原理 (三)脚本编写…

【数据分享】1981-2024年我国逐日平均气温栅格数据(免费获取)

气象数据一直是一个价值很高的数据,它被广泛用于各个领域的研究当中。这其中,又以平均气温数据最为常用!之前我们分享过来源于美国国家海洋和大气管理局(NOAA)下设的国家环境信息中心(NCEI)发布的1929-2024年全球站点的…

多模态PaliGemma——Google推出的基于SigLIP和Gemma的视觉语言模型

前言 本文怎么来的呢?其实很简单,源于上一篇文章《π0——用于通用机器人控制的流匹配VLA模型:一套框架控制7种机械臂(改造了PaliGemma和ACT的3B模型)》中的π0用到了PaliGemma 故本文便来解读下这个PaliGemma 第一部分 PaliGemma 1.1 Pal…

开源模型应用落地-glm模型小试-glm-4-9b-chat-Gradio集成(三)

一、前言 GLM-4是智谱AI团队于2024年1月16日发布的基座大模型,旨在自动理解和规划用户的复杂指令,并能调用网页浏览器。其功能包括数据分析、图表创建、PPT生成等,支持128K的上下文窗口,使其在长文本处理和精度召回方面表现优异&a…

ABAP开发学习——OLE

目录 1.概览 2.OEL的实现方式 3.OLE的配置 4.OLE的实现 4.1 OLE Demo 4.2 OLE实现的步骤 5.OLE实现样例 5.1 OLE中的的类型转换 5.2 变量定义 5.3 创建对象 5.4 表单页的操作 5.5 设置文件保存路径 5.6 文件是否可见 5.7 单元格操作 5.7.1 给单元格赋值 5.7.2…

在Java中,实现数据库连接通常使用JDBC

学习总结 1、掌握 JAVA入门到进阶知识(持续写作中……) 2、学会Oracle数据库入门到入土用法(创作中……) 3、手把手教你开发炫酷的vbs脚本制作(完善中……) 4、牛逼哄哄的 IDEA编程利器技巧(编写中……) 5、面经吐血整理的 面试技…

单臂路由实现不同VLAN之间设备通信

转载请注明出处 本实验为单臂路由配置,目的为让不同VLAN之间的设备能够互相通信。 1.首先,按照要求配置两个pc的ip地址,以pc0为例子: 2在交换机创建vlan10和vlan20 3.划分vlan,pc0为vlan10的设备,pc1为vla…

前后端交互通用排序策略

目录 排序场景 排序实现思路 1. 静态代码排序实现 2.数据库驱动排序实现 3. 基于Java反射的动态排序实现 通用排序工具 SortListUtil 结语 排序场景 在面向前端数据展示的应用场景中,我们旨在实现一个更加灵活的排序机制,该机制能够支持对从后端传递…

【华为云-云驻共创】UCS跨云多活容灾:让业务高可用不再是难题

【摘要】云原生应用深入到企业各个业务场景,云原生正在走向分布式化,跨云跨域统一协同治理,保证一致应用体验,这些新的需求日益凸显。而容灾是确保服务高可用的保障,但即使应用部署在云上,也无法避免市政方…

Linux内核编程(十九)SPI子系统的应用与驱动编写

本文目录 一、 SPI驱动框架图二、编写SPI驱动device框架三、编写SPI驱动driver框架四、实验一编写mcp2515驱动1. 注册字符设备或杂项设备框架2. SPI写数据3. SPI读寄存器数据 4. MCP2515相关配置 对于SPI基础知识这里不做过多讲解,详情查看:SPI基础知识实…

谍影重重5.0

打开流量包可以发现,流量中含有大量的smb加密通信,并且使用了ntlm v2加密协议进行身份认证 包过滤ntlmssp 认证后smb协议进行了大量的数据传输 取出tom的包内数据 得到以下数据 username:tomdomain: .NTProofStr: ca32f9b5b48c04ccfa96f35213d63d75NT…

qt QAbstractItemModel详解

1. 概述 QAbstractItemModel是Qt框架中的一个核心抽象基类,在Qt的模型/视图架构中扮演着至关重要的角色。这个类提供了一个接口,用于表示和管理数据,但不直接处理数据的存储。它的主要功能是为视图组件(如QListView、QTableView和…

华为OD机试 - 无重复字符的元素长度乘积的最大值(Python/JS/C/C++ 2024 C卷 100分)

华为OD机试 2024E卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试真题(Python/JS/C/C)》。 刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,…

【C++之STL】一文学会使用 string

文章目录 1. STL导读1. 1 什么是STL1. 2 STL的版本1. 3 STL六大组件1. 4 STL的重要性1. 5 STL的学习1. 6 STL系列博客的规划 2. string2. 1 为什么学习string类?2. 2 标准库中的string2. 3 基本构造2. 4 尾插与输出运算符重载2. 5 构造函数2. 6 赋值运算符重载2. 7 容量操作2.…