228 lines
7.2 KiB
Python
228 lines
7.2 KiB
Python
|
|
# -*- 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
|