PHP+MySQL事务处理示例代码

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:

注意支持事务的表必须是InnoDB类型。本例在 PHP5.2.5+MySQL5.0下测试通过。open_article 表的结构为:

    

 
  1. SET FOREIGN_KEY_CHECKS=0;  
  2.     — —————————-  
  3.     — Table structure for open_article  
  4.     — —————————-  
  5.     CREATE TABLE `open_article` (  
  6.       `nId` int(11) NOT NULL auto_increment,  
  7.       `nOrder` int(11) default ‘0′,  
  8.       `sTopic` varchar(100) default NULL,  
  9.       `sContent` varchar(255) default NULL,  
  10.       `dDatetime` timestamp NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP,  
  11.       PRIMARY KEY  (`nId`)  
  12.     ) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  13.  
  14.     <?PHP  
  15.       header(”Content-Type:text/html;charset=utf-8″);  
  16.  
  17.       $host = “localhost”;  
  18.       $user = “root”;  
  19.       $password = “mypassword”;  
  20.       $db = “test_store_proc”;  
  21.       $dblink = mysql_connect($host$user$passwordor die(”Can’t connect to mysql”);  
  22.       mysql_select_db($db$dblink);  
  23.       mysql_query(”SET NAMES UTF8″);  
  24.  
  25.       /* 创建事务 */ 
  26.       mysql_query(’START TRANSACTION’) or exit(mysql_error());  
  27.  
  28.       //第1条插入语句:  
  29.       $sql = “insert into open_article (nOrder, sTopic, sContent) values (0, ‘News Main Topic-1′,’资讯内容-1′)”;  
  30.       if(!mysql_query($sql))  
  31.       {  
  32.          echo $sql .’:<br>’. mysql_errno() . “:” . mysql_error() . “<br>”;  
  33.          mysql_query(’ROLLBACK’) or exit(’ROLLBACKing:’. mysql_error());  //判断当执行失败时回滚  
  34.          exit;  
  35.       }  
  36.  
  37.       //第2条插入语句:  
  38.       $sql = “insert into open_article (nOrder, sTopic, sContent) values (0, ‘News Main Topic-2′,’资讯内容-2′)”;  
  39.       if(!mysql_query($sql))  
  40.       {  
  41.         echo $sql .’:<br>’. mysql_errno() . “:” . mysql_error() . “<br>”;  
  42.         mysql_query(’ROLLBACK’) or exit(’ROLLBACKing:’. mysql_error());  //判断当执行失败时回滚  
  43.         exit;  
  44.       }  
  45.  
  46.       mysql_query(’COMMIT’) or exit(mysql_error());  //执行事务  
  47.  
  48.       mysql_close($dblink);  
  49.     ?>  
  50.  

    如果把第2条插入SQL语句改为:
    $sql = “insert into open_article (nOrder, sTopic2, sContent) values (0, ‘News Main Topic-2′,’资讯内容-2′)”;
    由于sTopic2字段不存在,程序会报错终止。这时会发现没有记录被插入到表中,说明第1条插入SQL语句也没有生效,实际是被事务回滚了。
    怎么看出是“被事务回滚了”?因为open_article表的有个自动增量字段 nId。当重新纠正第2条插入SQL语句,再运行程序时,会发现 nId 的值跳了1,说明前次第1条插入SQL语句确实被执行了,然后又被取消了。

    结果记录:

    — —————————-
    — Records
    — —————————-
    INSERT INTO `open_article` VALUES (’1′, ‘0′, ‘News Main Topic-1′, ‘资讯内容-1′, ‘2010-03-06 05:59:07′);
    INSERT INTO `open_article` VALUES (’2′, ‘0′, ‘News Main Topic-2′, ‘资讯内容-2′, ‘2010-03-06 05:59:07′);
    INSERT INTO `open_article` VALUES (’3′, ‘0′, ‘News Main Topic-1′, ‘资讯内容-1′, ‘2010-03-06 06:00:13′);
    INSERT INTO `open_article` VALUES (’4′, ‘0′, ‘News Main Topic-2′, ‘资讯内容-2′, ‘2010-03-06 06:00:13′);
    INSERT INTO `open_article` VALUES (’6′, ‘0′, ‘News Main Topic-1′, ‘资讯内容-1′, ‘2010-03-06 06:06:13′);
    INSERT INTO `open_article` VALUES (’7′, ‘0′, ‘News Main Topic-2′, ‘资讯内容-2′, ‘2010-03-06 06:06:13′);
    INSERT INTO `open_article` VALUES (’8′, ‘0′, ‘News Main Topic-1′, ‘资讯内容-1′, ‘2010-03-06 06:11:46′);
    INSERT INTO `open_article` VALUES (’9′, ‘0′, ‘News Main Topic-2′, ‘资讯内容-2′, ‘2010-03-06 06:11:46′);

    注意上列记录中,缺少 nId = 5 的记录。
    测试代码需要保存成 utf8 格式。















本文转自网眼51CTO博客,原文链接:http://blog.51cto.com/itwatch/286458,如需转载请自行联系原作者

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
20天前
|
安全 关系型数据库 MySQL
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
|
1月前
|
NoSQL 关系型数据库 MySQL
不是 PHP 不行了,而是 MySQL 数据库扛不住啊
【9月更文挑战第8天】这段内容讨论了MySQL在某些场景下面临的挑战及其原因,并指出这些问题不能完全归咎于MySQL本身。高并发读写压力、数据量增长以及复杂查询和事务处理都可能导致性能瓶颈。然而,应用程序设计不合理、系统架构不佳以及其他数据库选择和优化策略不足也是重要因素。综合考虑这些方面才能有效解决性能问题,而MySQL通过不断改进和优化,仍然是许多应用场景中的可靠选择。
|
2月前
|
存储 SQL 关系型数据库
PHP与MySQL交互的奥秘
【8月更文挑战第29天】在编程的世界里,PHP和MySQL就像是一对默契的舞伴,共同演绎着数据的交响曲。本文将带你探索它们之间的互动,从连接数据库到执行查询,再到处理结果,每一步都充满了节奏与和谐。我们将一起走进这段代码的旅程,感受数据流动的魅力。
|
2月前
|
SQL 关系型数据库 MySQL
PHP与MySQL交互之基础教程
【8月更文挑战第31天】 在数字世界中,数据是推动一切的核心力量。本文将引导你探索PHP与MySQL的协同工作,通过实际代码示例,展示如何建立连接、执行查询以及处理结果集。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你提供宝贵的实践知识。
|
2月前
|
SQL 存储 关系型数据库
MySQL事务处理
MySQL事务处理
32 0
|
3月前
|
数据库
基于PHP+MYSQL开发制作的趣味测试网站源码
基于PHP+MYSQL开发制作的趣味测试网站源码。可在后台提前设置好缘分, 自己手动在数据库里修改数据,数据库里有就会优先查询数据库的信息, 没设置的话第一次查询缘分都是非常好的 95-99,第二次查就比较差 , 所以如果要你女朋友查询你的名字觉得很好 那就得是她第一反应是查和你的缘分, 如果查的是别人,那不好意思,第二个可能是你。
54 3
|
3月前
|
Java API PHP
【亲测有效,官方提供】php版本企查查api接口请求示例代码,php请求企查查api接口,thinkphp请求企查查api接口
【亲测有效,官方提供】php版本企查查api接口请求示例代码,php请求企查查api接口,thinkphp请求企查查api接口
106 1
|
4月前
|
NoSQL 关系型数据库 MySQL
linux服务器重启php,nginx,redis,mysql命令
linux服务器重启php,nginx,redis,mysql命令
68 1
|
3月前
|
API PHP 开发者
​邮件发送API示例代码,AOKSend关于PHP示例代码
**邮件发送API简化了开发中的邮件功能,如自动化通知和营销邮件。常见示例包括SendGrid和Mailgun的Python代码。AOKSend在PHP中的使用示例展示了如何使用Guzzle库发送邮件,其特点包括高可靠性、易于集成和强大功能。通过API,开发者能高效、可靠地发送大规模邮件。**
|
4月前
|
Ubuntu 关系型数据库 MySQL
ubuntu apt 安装wordpress所需所有的 一键脚本 扩展您的PHP似乎没有安装运行WordPress所必需的MySQL扩展。
ubuntu apt 安装wordpress所需所有的 一键脚本 扩展您的PHP似乎没有安装运行WordPress所必需的MySQL扩展。
51 0
ubuntu apt 安装wordpress所需所有的 一键脚本 扩展您的PHP似乎没有安装运行WordPress所必需的MySQL扩展。