设为首页 收藏本站
查看: 445|回复: 0

[经验分享] mysql api---从一个小例子开始mysql编程入门(6)

[复制链接]

尚未签到

发表于 2018-10-6 14:05:44 | 显示全部楼层 |阅读模式
  先了解几个概念:
  MYSQL默认是自动提交的,也就是你提交一个QUERY,它就直接执行!我们可以通过
  set autocommit=0  禁止自动提交
  set autocommit=1 开启自动提交
  mysql中INNODB引擎才支持事务处理,默认是自动提交的;
  另外一种常用的MYISAM引擎是不支持事务的,本身就没有事务的概念
  从代码中来看:
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  //oracle的事务:事务起始标志 DML语言 (oracle默认事务似是打开的)
  //MYSQL默认是自动提交的 (每执行一个sql语言都给你自动提交)
  /*
  MySQL set autocommit = 0或1分别什么啊,哪个是自动提交啊
  要熟练使用mysql的帮助文档,在里面查找autocommit,就会有相应的注释,比我在这里直接给你说要深刻得多。
  autocoomit是事务,根据mysql的文档如果等于1是立即提交。但在transction中只有遇到commit或rollback才提交。希望对你有用。
  */
  #define BEGIN_TRAN      "START TRANSACTION"
  #define SET_TRAN            "SET AUTOCOMMIT=0"
  #define UNSET_TRAN      "SET AUTOCOMMIT=1"
  #define COMMIT_TRAN     "COMMIT"
  #define ROLLBACK_TRAN   "ROLLBACK"
  int mysql_BeginTran(MYSQL *mysql)
  {
  int ret = 0;
  

//--执行事务开始SQL  
ret = mysql_query(mysql, BEGIN_TRAN);
  
if (ret != 0)
  
{
  printf("func mysql_query() err: %d\n", ret);
  return ret;
  
}
  

  
//--设置事务手动提交
  
ret = mysql_query(mysql, SET_TRAN);
  
if (ret != 0)
  
{
  printf("func mysql_query() err: %d\n", ret);
  return ret;
  
}
  

  
return ret;
  

  }
  int mysql_Rollback(MYSQL *mysql)
  {
  int ret = 0;
  

//--事务回滚操作  
ret = mysql_query(mysql, ROLLBACK_TRAN);
  
if (ret != 0)
  
{
  printf("func mysql_query() err: %d\n", ret);
  return ret;
  
}
  

  
//--恢复事务自动提交标志
  
ret = mysql_query(mysql, UNSET_TRAN);
  
if (ret != 0)
  
{
  printf("func mysql_query() err: %d\n", ret);
  return ret;
  
}
  

  
return ret;
  

  }
  int mysql_Commit(MYSQL *mysql)
  {
  int ret = 0;
  

//--执行事务提交SQL  
ret = mysql_query(mysql, COMMIT_TRAN);
  
if (ret != 0)
  
{
  printf("func mysql_query() err: %d\n", ret);
  return ret;
  
}
  

  
//--恢复自动提交设置
  
ret = mysql_query(mysql, UNSET_TRAN);
  
if (ret != 0)
  
{
  printf("func mysql_query() err: %d\n", ret);
  return ret;
  
}
  

  
return ret;
  

  }
  // drop table test_table
  // 建表 create table test_table(col1 int, col2 varchar(10), col3 varchar(10));
  #define sql01 "INSERT INTO test_table(col1,col2,col3) VALUES(10, '10', '1')"
  #define sql02 "INSERT INTO test_table(col1,col2,col3) VALUES(20, '20', '2')"
  #define sql03 "INSERT INTO test_table(col1,col2,col3) VALUES(30, '30', '3')"
  #define sql04 "INSERT INTO test_table(col1,col2,col3) VALUES(40, '40', '4')"
  int main()
  {
  int         ret = NULL;
  

MYSQL       *mysql;  

  
MYSQL_RES   *res;
  
MYSQL_ROW   row;
  
char        *query;
  

  
mysql = mysql_init(NULL);
  

  
mysql =mysql_real_connect(mysql, "localhost", "root", "123456", "mydb2", 0, NULL, 0 );
  
if (mysql == NULL)
  
{
  ret = mysql_errno(mysql);
  printf("func mysql_real_connect() err\n");
  return ret;
  
}
  
else
  
{
  printf(" ok......\n");
  
}
  

  
ret = mysql_BeginTran(mysql); //修改事务的属性,变成不自动 提交
  
if (ret != 0)
  
{
  printf("mysql_BeginTran() err:%d\n", ret);
  return ret;
  
}
  
ret = mysql_query(mysql, sql01);
  
if (ret != 0)
  
{
  printf("mysql_query() err:%d\n", ret);
  return ret;
  
}
  
ret = mysql_query(mysql, sql02);
  
if (ret != 0)
  
{
  printf("mysql_query() err:%d\n", ret);
  return ret;
  
}
  
ret = mysql_Commit(mysql); //提交事务,恢复事务的默认属性
  
if (ret != 0)
  
{
  printf("mysql_Commit() err:%d\n", ret);
  return ret;
  
}
  

  
ret = mysql_BeginTran(mysql);
  
if (ret != 0)
  
{
  printf("mysql_BeginTran() err:%d\n", ret);
  return ret;
  
}
  
ret = mysql_query(mysql, sql03);
  
if (ret != 0)
  
{
  printf("mysql_query() err:%d\n", ret);
  return ret;
  
}
  
ret = mysql_query(mysql, sql04);
  
if (ret != 0)
  
{
  printf("mysql_query() err:%d\n", ret);
  return ret;
  
}
  
ret = mysql_Rollback(mysql);
  
if (ret != 0)
  
{
  printf("mysql_Rollback() err:%d\n", ret);
  return ret;
  
}
  

  
mysql_close(mysql);
  

  }
  结果显然sql1 sql2 commit 生效
  sql3  sql4 rollback回滚无效



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-613998-1-1.html 上篇帖子: mysql api---从一个小例子开始mysql编程入门(5) 下篇帖子: mysql api---从一个小例子开始mysql编程入门(6)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表