MYSQL默认是自动提交的,也就是你提交一个QUERY,它就直接执行!我们可以通过

set autocommit=0 禁止自动提交

set autocommit=1开启自动提交

mysql中INNODB引擎才支持事务处理,默认是自动提交的;

另外一种常用的MYISAM引擎是不支持事务的,本身就没有事务的概念 .

可类比Oracle事务的概念!!!

能够避免MySQL的自动提交,自己封装API以后实现回滚等操作!!!#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

/*

MySQL set autocommit = 0或1分别什么啊,哪个是自动提交啊

要熟练使用mysql的帮助文档,在里面查找autocommit,就会有相应的注释,比我在这里直接给你说要深刻得多。

autocoomit是事务,根据mysql的文档如果等于1是立即提交。但在transction中只有遇到commit或rollback才提交。希望对你有用。

*/

/*

MYSQL默认是自动提交的,也就是你提交一个QUERY,它就直接执行!我们可以通过

set autocommit=0 禁止自动提交

set autocommit=1 开启自动提交

mysql中INNODB引擎才支持事务处理,默认是自动提交的;

另外一种常用的MYISAM引擎是不支持事务的,本身就没有事务的概念

*/

#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;

}

// 建表 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);

}

以上就是MySQL入门之事务概念的内容,更多相关内容请关注PHP中文网(www.gxlcms.com)!

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

mysql自动提交的概念_MySQL入门之事务概念相关推荐

  1. mysql自动提交 dcl语句_MySQL基础:DCL语句总结

    SQL语言大致分为DCL.DDL.DML三种,本文主要介绍MySQL 5.7版本DCL语句. 概述 DCL(Data Control Language)语句:数据控制语句,用于控制不同数据段直接的许可 ...

  2. java mysql 自动提交_详解MySQL与Spring的自动提交(autocommit)

    1 MySQL的autocommit设置 MySQL默认是开启自动提交的,即每一条DML(增删改)语句都会被作为一个单独的事务进行隐式提交.如果修改为关闭状态,则执行DML语句之后要手动提交 才能生效 ...

  3. mysql不自动提交更改语句_MySQL设置事务自动提交(开启和关闭)

    MySQL 默认开启事务自动提交模式,即除非显式的开启事务(BEGIN 或 START TRANSACTION),否则每条 SOL 语句都会被当做一个单独的事务自动执行.但有些情况下,我们需要关闭事务 ...

  4. mysql开启事务_MySQL入门之事务(上)

    事务 事务介绍 事务的概念 事务指逻辑上的一组操作,组成这组操作的各个单元,要不全部成功,要不全部不成功 数据库开启事务命令 start transaction 开启事务 (等同于set autoco ...

  5. java mysql 自动提交_Mybatis的JDBC提交设置/关闭mysql自动提交------关于mysql自动提交引发的惨剧...

    学习Mybatis时提到了JDBC方式需要自己手动提交事务,如果不加session.commit会导致数据库的数据无法正常插入(程序本身又不给你报错,还装出一副我已经插入成功的样子) SqlSessi ...

  6. mysql自动写入创建时间_mysql 自动记录数据插入及最后修改时间

    总结: `uptime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP 应用场景: 1.在数据表中, ...

  7. mysql自动获取时间列_mysql自动获取时间日期的方法

    实现方式: 1.将字段类型设为 TIMESTAMP 2.将默认值设为 CURRENT_TIMESTAMP 举例应用: 1.MySQL 脚本实现用例 --添加CreateTime 设置默认时间 CURR ...

  8. mysql 自动备份 发邮件_MYSQL自动备份并发送邮件工具

    最近在开发小程序,由于服务器只有一台,所以不能数据库异机备份,出于数据安全的考虑,就做了一个数据库定时备份并发送邮件到自己的邮箱的小工具,先看下工具界面 这个工具主要涉及到三个部分 1.MYSQL自动 ...

  9. mysql自动生成id方式_Mysql全局ID生成方法

    本文给大家介绍mysql全局id生成方法,涉及到mysql全局id相关知识,感兴趣的朋友一起学习吧 生产系统随着业务增长总会经历一个业务量由小变大的过程,可扩展性是考量数据库系统高可用性的一个重要指标 ...

最新文章

  1. SuperEdge — Overview
  2. 杭电1789贪心java实现
  3. 多车调度问题(大疆Robot Master)——ROS键盘控制失灵,小车无法收敛定位,路径规划出错
  4. wenbao与最优比率生成树
  5. Linux 下 GitLab 安装教程
  6. URL(统一资源定位符)
  7. 彩虹云商城6.6特别版源码
  8. 【Codeforces #228】Solutions
  9. 一些iptables的具体应用
  10. Ethereum Casper 101
  11. C# Console Application
  12. 《史上最简单的 SpringCloud 教程》系列 (转载 http://blog.csdn.net/forezp/article/details/70148833 本文出自方志朋的博客)
  13. 319@365 RStudio中rgl包安装后调用出错解决方法初探。
  14. scrapy项目部署
  15. 深度学习实战-图像风格迁移
  16. Windows 11强势来袭,一文带你了解全部更新内容
  17. Android传感器之陀螺仪传感器
  18. ingress的yaml配置文件
  19. 悠漓带你浅谈C语言2(数据类型)
  20. 记录小程序后端开发环境配置

热门文章

  1. 30-Python3 正则表达式
  2. mysql中生成列与JSON类型的索引
  3. 洛谷 2449 [SDOI2005]矩形
  4. centos7和scientific linux7里面调出中文输入法
  5. 函数定义的规范-电子书包
  6. issues:close 云端 STS 启动报找不到 jdk
  7. 利用jquery.validate异步验证用户名是否存在
  8. 枚举、位操作 CLR学习第十二课
  9. Android自定义ImageView(二)——实现双击放大与缩小图片
  10. python 函数内部声明全局变量