pymysql在链接ob时cursor.execute执行完未提交会直接入库,导致最终无法回滚

【 使用环境 】 测试环境(生产也是有此问题)
【 OB or 其他组件 】ob
【 使用版本 】企业版3.2.4
【问题描述】 pymysql链接mysql的时候cursor.execute(执行完这句,没有commit的时候,数据不会入库,但是ob就直接入库了,然后正常是如果cursor.execute有问题,需要执行回滚语句的,cursor.execute直接提交了的话都没法回滚了。必须每次在cursor这个会话前执行一下SET autocommit = 0。
pymysql用法:
import pymysql
db_config = {
“host”: “1xxx”, # MySQL 主机地址
“port”: xxx, # MySQL 端口号
“user”: “xxx”, # MySQL 用户名
“password”: “xx”, # MySQL 密码
“database”: “xxx”, # 数据库名称
# “autocommit”: False
}
connection = pymysql.connect(**db_config)
cursor = connection.cursor()
cursor.execute(“INSERT INTO szyg_portal.t_logs_202412 (id, active, create_time, create_user_id, ip, action, resource, desc) VALUES (299999, 1, ‘2024-12-01 00:02:02’, -1, ‘’, ‘1’, ‘15’, ‘1’);”) # 插入多条数据
cursor.close()
connection.close()

因为这个原因导致python一堆框架的 orm库都不能执行回滚操作了
框架用法如下
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

Base = declarative_base()

class User(Base):
tablename = ‘users’
id = Column(Integer, primary_key=True)
name = Column(String)

创建数据库引擎和会话

engine = create_engine(‘mysql+pymysql://root:mysql@192.168.0.17:12881/test’)
Session = sessionmaker(bind=engine)
session = Session()
session.execute(“SET autocommit = 0”) # 必须设置,否则session.flush()没有作用,框架中执行完flash能得到插入数据的id, 不设置则只能执行commit操作,就无法回滚了
try:
# 添加一个新用户
new_user = User(name=‘11111’)
session.add(new_user)
session.flush()
session.commit()
except Exception as e:
# 发生异常时回滚事务
session.rollback()
print(f"An error occurred: {e}")
finally:
# 关闭会话
session.close()
【复现路径】问题出现前后相关操作
【附件及日志】推荐使用OceanBase敏捷诊断工具obdiag收集诊断信息,详情参见链接(右键跳转查看):

【SOP系列 22 】——故障诊断第一步(自助诊断和诊断信息收集)

【备注】基于 LLM 和开源文档 RAG 的论坛小助手已开放测试,在发帖时输入 [@论坛小助手] 即可召唤小助手,欢迎试用!

您好,您提的这个技术问题可能牵涉到 OceanBase 企业版范围内的功能细节;针对此类问题,建议你通过以下方式寻求帮助:

  1. 如你所在的企业客户已签署 OceanBase 企业版销售合同,请你联系客户经理;

  2. 如你所在的企业客户尚未签署 OceanBase 企业版销售合同,你可通过OceanBase官网商务咨询页面留下你的联系方式,OceanBase企业版的业务顾问会在一个工作日内与你联系。

另外,我们欢迎你使用社区版,并在论坛/社群中分享你对社区版本的想法、经验和问题,与其他社区成员共同交流。

(小助手的答复已结束,如未能解决您的问题,请继续提问并等待其他同学的回复,谢谢!)

你都知道问题了啊。。就是因为开了自动提交,原生mysql也是这样的行为 :joy:

但是连接mysql的时候不用每次都关闭自动提交

autocommit可以调整的,可以设置set global autocommit=0,这样不用每次都设置了

https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000001431569

你这边以前是怎么连接的原生mysql?
也是这样还是说用了其他框架或者中间件,会不会是框架或者中间在你使用的时候自己关闭自动提交了?
也可以按照官方说的关闭全局的自动提交

测试的时候也是pymysql像上面一样去操作的