# -*- coding: UTF-8 -*- import pymysql from loguru import logger from dbutils.pooled_db import PooledDB """ @功能:创建数据库连接池 """ class MyConnectionPool(object): __pool = None def __init__(self, content): self.conn = self.__getConn(content) self.cursor = self.conn.cursor() # 创建数据库连接conn和游标cursor # def __enter__(self): # self.conn = self.__getconn() # self.cursor = self.conn.cursor() # 创建数据库连接池 def __getconn(self, content): if self.__pool is None: self.__pool = PooledDB( creator=pymysql, mincached=int(content["mysql"]["db_min_cached"]), maxcached=int(content["mysql"]["db_max_cached"]), maxshared=int(content["mysql"]["db_max_shared"]), maxconnections=int(content["mysql"]["db_max_connecyions"]), blocking=content["mysql"]["db_blocking"], maxusage=content["mysql"]["db_max_usage"], setsession=content["mysql"]["db_set_session"], host=content["mysql"][content["dsp"]["active"]]["host"], port=content["mysql"][content["dsp"]["active"]]["port"], user=content["mysql"][content["dsp"]["active"]]["username"], passwd=content["mysql"][content["dsp"]["active"]]["password"], db=content["mysql"][content["dsp"]["active"]]["dbname"], use_unicode=False, charset=content["mysql"]["db_charset"] ) return self.__pool.connection() # 释放连接池资源 # def __exit__(self, exc_type, exc_val, exc_tb): # self.cursor.close() # self.conn.close() # 关闭连接归还给链接池 def close(self): self.cursor.close() self.conn.close() # 从连接池中取出一个连接 def getconn(self, content): conn = self.__getconn(content) cursor = conn.cursor() return cursor, conn # 获取连接池,实例化 def get_my_connection(content): return MyConnectionPool(content) ''' 执行语句查询有结果返回结果没有返回0;增/删/改返回变更数据条数,没有返回0 ''' class MySqLHelper(object): def __init__(self, content): logger.info("开始加载数据库连接池!") self.db = get_my_connection(content) logger.info("加载数据库连接池完成!") def __new__(cls, *args, **kwargs): if not hasattr(cls, 'inst'): # 单例 cls.inst = super(MySqLHelper, cls).__new__(cls, *args, **kwargs) return cls.inst # 封装执行命令 def execute(self, sql, param=None, autoclose=False): """ 【主要判断是否有参数和是否执行完就释放连接】 :param sql: 字符串类型,sql语句 :param param: sql语句中要替换的参数"select %s from tab where id=%s" 其中的%s就是参数 :param autoclose: 是否关闭连接 :return: 返回连接conn和游标cursor """ cursor, conn = self.db.getconn() # 从连接池获取连接 count = 0 try: # count : 为改变的数据条数 if param: count = cursor.execute(sql, param) else: count = cursor.execute(sql) conn.commit() if autoclose: self.close(cursor, conn) except Exception as e: pass return cursor, conn, count # 执行多条命令 # def executemany(self, lis): # """ # :param lis: 是一个列表,里面放的是每个sql的字典'[{"sql":"xxx","param":"xx"}....]' # :return: # """ # cursor, conn = self.db.getconn() # try: # for order in lis: # sql = order['sql'] # param = order['param'] # if param: # cursor.execute(sql, param) # else: # cursor.execute(sql) # conn.commit() # self.close(cursor, conn) # return True # except Exception as e: # print(e) # conn.rollback() # self.close(cursor, conn) # return False # 释放连接 def close(self, cursor, conn): logger.info("开始释放数据库连接!") cursor.close() conn.close() logger.info("释放数据库连接完成!") # 查询所有 def selectall(self, sql, param=None): try: cursor, conn, count = self.execute(sql, param) res = cursor.fetchall() return res except Exception as e: logger.error("查询所有数据异常:") logger.exception(e) self.close(cursor, conn) return count # 查询单条 def selectone(self, sql, param=None): try: cursor, conn, count = self.execute(sql, param) res = cursor.fetchone() self.close(cursor, conn) return res except Exception as e: logger.error("查询单条数据异常:") logger.exception(e) self.close(cursor, conn) return count # 增加 def insertone(self, sql, param): try: cursor, conn, count = self.execute(sql, param) # _id = cursor.lastrowid() # 获取当前插入数据的主键id,该id应该为自动生成为好 conn.commit() self.close(cursor, conn) return count # 防止表中没有id返回0 # if _id == 0: # return True # return _id except Exception as e: logger.error("新增数据异常:") logger.exception(e) conn.rollback() self.close(cursor, conn) return count # 增加多行 def insertmany(self, sql, param): """ :param sql: :param param: 必须是元组或列表[(),()]或((),()) :return: """ cursor, conn, count = self.db.getconn() try: cursor.executemany(sql, param) conn.commit() return count except Exception as e: logger.error("增加多条数据异常:") logger.exception(e) conn.rollback() self.close(cursor, conn) return count # 删除 def delete(self, sql, param=None): try: cursor, conn, count = self.execute(sql, param) self.close(cursor, conn) return count except Exception as e: logger.error("删除数据异常:") logger.exception(e) conn.rollback() self.close(cursor, conn) return count # 更新 def update(self, sql, param=None): try: cursor, conn, count = self.execute(sql, param) conn.commit() self.close(cursor, conn) return count except Exception as e: logger.error("更新数据异常:") logger.exception(e) conn.rollback() self.close(cursor, conn) return count