数据库连接池

为啥要使用数据库连接池

  • 频繁的连接和断开数据库,消耗大,效率低
  • DBUtils可以创建多个线程连接数据库,且一直保持连接,不会断开
  • 执行数据库操作时,由数据池分配线程,当数据池空时,可选择等待或者抛错

安装

pip3 install DBUtils

基础用法

  • 创建数据池
    import time
    import threading import pymysql
    from DBUtils.PooledDB import PooledDB # 创建数据库连接池
    POOL = PooledDB(
    creator=pymysql,
    maxconnections=20, # 定义最大连接数
    mincached=2, # 定义起始连接数
    host='127.0.0.1',
    blocking=True, # 连接池用完时,True是等待,False时抛错
    port=3306,
    user='root',
    password='123',
    database='pooldb',
    charset='utf8'
    ) # 去数据库连接池获取一个连接
    conn = POOL.connection() cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    cursor.execute('select * from tb1')
    result = cursor.fetchall() # 将此连接放还给连接池
    conn.close()

在flask中应用

  • 定义

    import pymysql
    
    from DBUtils.PooledDB import PooledDB
    
    class SQLHelper(object):
    def __init__(self):
    # 创建数据库连接池
    self.pool = PooledDB(
    creator=pymysql,
    maxconnections=5,
    mincached=2,
    blocking=True,
    host='127.0.0.1',
    port=3306,
    user='root',
    password='123',
    database='s23day02',
    charset='utf8'
    ) def connect(self):
    conn = self.pool.connection()
    cursor = conn.cursor()
    return conn,cursor def disconnect(self,conn,cursor):
    cursor.close()
    conn.close() def fetchone(self,sql,params=None):
    """
    获取单条
    :param sql:
    :param params:
    :return:
    """
    if not params:
    params = []
    conn,cursor = self.connect()
    cursor.execute(sql, params)
    result = cursor.fetchone()
    self.disconnect(conn,cursor)
    return result def fetchall(self,sql,params=None):
    """
    获取所有
    :param sql:
    :param params:
    :return:
    """
    import pymysql
    if not params:
    params = []
    conn, cursor = self.connect()
    cursor.execute(sql,params)
    result = cursor.fetchall()
    self.disconnect(conn, cursor)
    return result def commit(self,sql,params):
    """
    增删改
    :param sql:
    :param params:
    :return:
    """
    import pymysql
    if not params:
    params = [] conn, cursor = self.connect()
    cursor.execute(sql, params)
    conn.commit()
    self.disconnect(conn, cursor) db = SQLHelper()
  • 使用单例模式进行

    from flask import Blueprint,url_for,request,render_template,session,redirect
    from ..utils.sqlhelper import db # 创建了一个蓝图对象
    account = Blueprint('account',__name__) @account.route('/login',methods=['GET','POST'])
    def login(): if request.method == 'GET':
    return render_template('login.html')
    user = request.form.get('user')
    pwd = request.form.get('pwd') # 根据用户名和密码去数据库进行校验
    # 连接/SQL语句/关闭
    result = db.fetchone('select * from user where username=%s and password=%s',[user,pwd])
    if result:
    # 在session中存储一个值
    session['user_info'] = user
    return redirect(url_for('user.user_list'))
    return render_template('login.html',error="用户名或密码错误")

【说明】SQLhelper类

  • 封装了数据库操作的相关方法,以便之后业务功能调取,在一定程度上时减少了代码的重复
  • 配合DBUtils,大大提高数据库的操作效率

flask数据库连接池DBUtils的更多相关文章

  1. Python数据库连接池---DBUtils

    Python数据库连接池DBUtils   DBUtils是Python的一个用于实现数据库连接池的模块. 此连接池有两种连接模式: 模式一:为每个线程创建一个连接,线程即使调用了close方法,也不 ...

  2. Python数据库连接池DBUtils

    Python数据库连接池DBUtils   DBUtils是Python的一个用于实现数据库连接池的模块. 此连接池有两种连接模式: 模式一:为每个线程创建一个连接,线程即使调用了close方法,也不 ...

  3. Flask中使用数据库连接池 DBUtils ——(4)

    DBUtils是Python的一个用于实现数据库连接池的模块. 此连接池有两种连接模式: 模式一:为每个线程创建一个连接,线程即使调用了close方法,也不会关闭,只是把连接重新放到连接池,供自己线程 ...

  4. Flask的数据库连接池 DBUtils

    Flask是没有ORM的操作的,如果在flask中连接数据库有两种方式 一.pymysql 二.SQLAlchemy 是python操作数据库的以一个库,能够进行orm映射官网文档 sqlchemy ...

  5. Flask(4):wtforms组件 & 数据库连接池 DBUtils

    wtforms 组件的作用: --- 生成 HTML 标签 --- form 表单验证 示例代码: app.py from flask import Flask, render_template, r ...

  6. Python-flask中数据库连接池DBUtils

    一.DBUtils DBUtils是Python的一个用于实现数据库连接池的模块. 连接池的三种模式: 第一种模式:             它的缺点:每一次请求反复创建数据库的链接,链接的次数太多 ...

  7. Python数据库连接池DBUtils.PooledDB

    DBUtils 是一套用于管理数据库连接池的包,为高频度高并发的数据库访问提供更好的性能,可以自动管理连接对象的创建和释放.最常用的两个外部接口是 PersistentDB 和 PooledDB,前者 ...

  8. python之数据库连接池DBUtils

    DBUtils 是Python 的一个用于实现数据库连接池的模块. 此连接池有两种连接模式: DBUtils :提供两种外部接口: PersistentDB :提供线程专用的数据库连接,并自动管理连接 ...

  9. Python的数据库连接池DBUtils

    DBUtils是Python的一个用于实现数据库连接池的模块. 此连接池有两种连接模式: 模式一:为每个线程创建一个连接,线程即使调用了close方法,也不会关闭,只是把连接重新放到连接池,供自己线程 ...

随机推荐

  1. 前端知识体系:JavaScript基础-原型和原型链-理解 es6 中class构造以及继承的底层实现原理

    理解 es6 中class构造以及继承的底层实现原理 原文链接:https://blog.csdn.net/qq_34149805/article/details/86105123 1.ES6 cla ...

  2. 007_STM32程序移植之_多通道ADC转换

    1. 测试环境:STM32C8T6 2. 测试:使用DMA进行多通道ADC转换 3. 描述:用 ADC 连续采集 12 路模拟信号,并由 DMA 传输到内存.ADC 配置为扫描 并且连续转换模式,AD ...

  3. leetcode解题报告(1):Remove Duplicates from Sorted Array

    描述 Given a sorted array, remove the duplicates in place such that each element appear only once and ...

  4. GAN生成式对抗网络(二)——tensorflow代码示例

    代码实现 当初学习时,主要学习的这个博客 https://xyang35.github.io/2017/08/22/GAN-1/ ,写的挺好的. 本文目的,用GAN实现最简单的例子,帮助认识GAN算法 ...

  5. codeforces 1272F dp+记录路径

    题意 给出两个括号序列 \(S\) 和 \(T\),让你构造一个最短的合法括号序列使 \(S\) 和 \(T\) 是它的子序列. 分析 设 \(dp[i][j][k]\) 为这个最短的合法括号序列的前 ...

  6. 解决Virtualbox的根分区容量不够用问题

    现在Virtualbox新建一块磁盘.容量一定要比原来的大.然后执行克隆命令. 把原来的磁盘内容克隆到新磁盘上.然后重新启动电脑. 运行相关扩容命令即可. #克隆磁盘 cd C:\Program Fi ...

  7. 解决python中文乱码的方法

    首先需要说明的是,windows下的文件路径,cmd窗口等默认编码都是gbk 但在windows下编写python程序的时候,我们一般采用的编码是utf-8 二者不一致是导致乱码的根本原因! 在pyc ...

  8. @Transactional注解不生效的原因总结(整理网上和自己遇到的解决方案)

    1.问题背景 今天做项目,发现配置好@Transactional后,没有生效,事务没有回滚,即便在网上查资料,也没有解决,好像网上没有人发过我遇见的这种情况的帖子. 2.自己遇到的情况分析 代码结构图 ...

  9. Qt pro工程文件介绍

    app - 建立一个应用程序的makefile.这是默认值,所以如果模板没有被指定,这个将被使用. lib - 建立一个库的makefile. vcapp - 建立一个应用程序的Visual Stud ...

  10. linux系统安装Memcache

    Linux系统安装memcached 首先要先安装libevent库. centos  下执行 yum install libevent libevent-devel 查看memcached 是否已经 ...