MYSQL怎么操作OTL中使用事物?

迷之程序员 2018-09-20 08:32:42
一直使用otl操纵mysql,但是现在导入大量数据的时候,出问题不能回滚就很麻烦。
希望能够通过otl声明一个mysql的事物,手动操纵什么时候对这个事物进行提交。
网上关于otl mysql的例子很少,都是关于oracle。但是两者有区别,oracle中事务从上一个commit或rollback开始;但是MySQL中事务的开始必须要有START TRANSACTION;这才标志着一个事物的开始,否则使用rollback是无法回滚数据的
比如
void updateNoAutoCommit()
{
// create update stream
otl_stream s(2, // buffer size
"update person_tab set age=:v_age<int> where age<:v_age2<int>",// UPDATE statement
db // connect object
);
s.set_flush(false);
s.set_commit(0);

s<<31;//assgining :v_age =31
s<<2000; //assigning :v_age2 = 2000

s.flush();
db.commit();

就无法操纵MYSQL
...全文
240 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
luijianfie 2018-09-20
  • 打赏
  • 举报
回复
设置关闭autocommit,mysql隐式开启事务,只有commit才全部提交。
luijianfie 2018-09-20
  • 打赏
  • 举报
回复
连接mysql,设置关闭autocommit不可以?

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧