Python 连接 Doris pymysql游标cursor.excute(sql) 并且添加事务和自动重连操作

 pymysql.cursors 普通连接:

import pymysql.cursors
conn = pymysql.connect(host="127.0.0.1",port=9030, user="root", password="", database="ssb", charset='utf8')
mycursor = conn.cursor()
mycursor.execute("select * from lineorder_rt limit 1")
result = mycursor.fetchall()
for data in result:
  print(data)

# 使用完后,要把游标和 连接都要关闭掉
cursor.close()
conn.close()

问题:为了避免出现连接超时中断错误
sqlalchemy.exc.OperationalError: (pymysql.err.OperationalError)(2013,'Lost connection to MySQL server during query')

添加事务操作后的连接:

        import pymysql.cursors
        connect = pymysql.connect(host="127.0.0.1", port=8090, user=self.user_doris_prd, password=self.password_doris_prd, database="ads", charset='utf8')
        
        while True:
            try:
                with connect.cursor() as cursor:  # 获取游标
                    cursor.execute(sql)
                connect.commit()
                result = cursor.fetchone()

                # 使用完后,要把游标和 连接都要关闭掉
                cursor.close()
                connect.close()

                for data in result:
                    print(data)
                break
            except Exception:
                connect.ping(True)

补充:cursor 提供了 fetchone()、fetchall() 和 fetchmany() 函数

参考:python中查询数据库用到的 fetchone()、fetchall()和fetchmany() 函数_cur.fetchall()-CSDN博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SunTecTec

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值