pymysql 重试连接数据库

from pymysql import connect
from retrying import retry
class Down_Pdf():
    def __init__(self):
        self.mysql_host = '127.0.0.1'
        self.mysql_port = 3306
        self.mysql_user = 'root'
        self.mysql_password = 'xxxx'
        self.mysql_db = 'datadb'
        self.conn = connect(host=self.mysql_host, port=self.mysql_port, user=self.mysql_user,password=self.mysql_password, db=self.mysql_db, charset='utf8mb4')
        self.cur = self.conn.cursor()

    def new_link(self):#重新连接数据库
        self.conn = connect(host=self.mysql_host, port=self.mysql_port, user=self.mysql_user,password=self.mysql_password, db=self.mysql_db, charset='utf8mb4')
        self.cur = self.conn.cursor()

    @retry(stop_max_attempt_number=6, wait_fixed=2000)
    def all_search(self, sql, data=None, to_json=False):
        """
        :param sql:select id from table where param1=%s and param2=%s
        :param data:list [(1,2),(3,4)]
        :param to_json:  返回结果转成字典
        """
        try:
            self.conn.ping()
        except:
            self.new_link()
        results = []
        if data:
            for i in data:
                self.cur.execute(sql % i)
                datas = self.cur.fetchall()
                self.conn.commit()
                if to_json:
                    if not data:
                        return {}
                    columns = [i[0] for i in self.cur.description]
                    datas = [dict(zip(columns, r)) for r in datas]
                results += list(datas)
        else:
            self.cur.execute(sql)
            datas = self.cur.fetchall()
            self.conn.commit()
            if to_json:
                if not datas:                     
                    return {}
                columns = [i[0] for i in self.cur.description]
                datas = [dict(zip(columns, r)) for r in datas]
            results += list(datas)
        return results

    @retry(stop_max_attempt_number=6, wait_fixed=2000)
    def one_search(self, sql, to_json=False):
        """
        :param sql:
        :param to_json: 返回结果转成字典
        """
        try:
            self.conn.ping()
        except:
            self.new_link()
        self.cur.execute(sql)
        data = self.cur.fetchone()
        if to_json:
            if not data:                     
                return {}
            columns = [i[0] for i in self.cur.description]
            data = dict(zip(columns, data))
        self.conn.commit() # 每次查询后进行事务提交,下次查询到数据库更新后的数据
        return data
        
    @retry(stop_max_attempt_number=6, wait_fixed=2000)
    def submit_data(self, sql):
        try:
            self.conn.ping()
        except:
            self.new_link()
        self.cur.execute(sql)
        self.conn.commit()

    @retry(stop_max_attempt_number=6, wait_fixed=2000)
    def close(self):
        try:
            self.conn.ping()
        except:
            self.new_link()
        self.cur.close()
        self.conn.close()

    @retry(stop_max_attempt_number=6, wait_fixed=2000)
    def execute_many(self, sql, data):
        """
        :param sql: 写入/查询
        :param data: [(1,2,3)]
        :param to_result:  返回结果
        :param to_json:  返回结果转成字典
        """
        if not data: return
        try:
            self.conn.ping()
        except:
            self.new_link()
        try:
            self.conn.ping(reconnect=True)
            self.cur.executemany(sql, data)
            self.conn.commit()
        except Exception as e:
            print(e)
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值