搜索
首页后端开发php教程php事务处理实例详解,php事务处理详解_PHP教程

php事务处理实例详解,php事务处理详解

一、php事务处理概述:

事务:是若干事件的集合
事务处理:当所有事件执行成功,事务才执行;若有任何一个事件不能成功执行,事务的其它事件也不被执行。

只要你的MySQL版本支持BDB或InnoDB表类型,那么你的MySQL就具有事务处理的能力。这里面,又以InnoDB表类型用的最多,虽然后来发生了诸如Oracle收购InnoDB等令MySQL不爽的事情,但是这类商业事件与技术无关,下面就以InnoDB表类型为例简单说一下MySQL中的事务处理。

二、php事务处理代码:

<&#63;php
 try{
 $pdo=new PDO("mysql:host=localhost;dbname=psp","root","");
 $pdo->exec("set names utf8");
 $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);//设置异常处理模式
 $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0);//关闭自动提交
 }catch(PDOException $e){
 echo "数据库连接失败";
 exit;
 }

 try{
 $age=10;
 $pdo->beginTransaction();//开始事务
 $affected_rows1=$pdo->exec("update kfry set k_age=k_age+{$age} where k_name='user1'");
 $affected_rows2=$pdo->exec("update kfry set k_age=k_age-{$age} where k_name='user2'");//随意更改使之执行成功或失败
 /* if($affected_rows1&&$affected_rows2)
 {
  $pdo->commit();
  echo "操作成功";
 }else{
  $pdo->rollback();
 } */
 if(!$affected_rows1)
  throw new PDOException("加入错误");
 if(!$affected_rows2)
  throw new PDOException("减少错误");
 echo "操作成功";
 $pdo->commit();//如果执行到此处前面两个更新sql语句执行成功,整个事务执行成功
 }catch(PDOException $e){
 echo "操作失败:".$e->getMessage();
 $pdo->rollback();//执行事务中的语句出了问题,整个事务全部撤销
 }
 $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1);
 //测试是否成功
 echo "\n操作结果为:\n";
 $sql="select * from kfry";
 $result=$pdo->query($sql);
 foreach($result as $v)
 {
 echo $v['k_name']." ".$v['k_age']."\n";
 }
&#63;>

PHP一般是怎做SQL事务处理的

EC中有事务处理,PHP怎么实现这个还真没研究过,回家研究研究再告诉你
 

php练级步骤

第一阶段第一讲,WEB基础 1.1 网站基本知识;1.2 网络协议介绍; 1.3 B/S与C/S结构的区别;1.4 WEB编程、网站开发技术介绍。 第二讲,网页设计 2.1 Dreamweaver介绍及使用;2.2 静态网页HTML语言; 2.3 标题与段落,换行与分割线;2.4 表格、表单;2.5 框架、超链接、图片。 实例:1,使用表格进行网页布局设计; 2,使用表单、表格、框架进行系统后台界面设计。第三讲,DIV+CSS 3.1 CSS的概念及基本语法;3.2 用CSS设置丰富的文字效果设置图片效果; 3.3 用CSS设置表格与表单的样式,用CSS设置页面和浏览器的元素;3.4 CSS盒模型;3.7 CSS+DIV布局,CSS+DIV美化与布局实战。 实例:1,使用DIV+CSS设计按钮及Tab; 2,使用DIV+CSS设计导航菜单;3,使用DIV+CSS设计论坛网页;4,使用DIV+CSS设计博客网页。第四讲,PHP开发环境 4.1 集成开发环境XAMPP安装;4.2 Zend Studio的安装、配置; 4.3 Eclipse PDT的安装与配置;4.4 编写第一个PHP程序;4.5 调试PHP程序。 第五讲,PHP编程基础 5.1 PHP语言特性与发展趋势;5.2 PHP变量常量数据类型; 5.3 PHP运算符与表达式;5.4 PHP流程控制语句;5.5 PHP函数。 第六讲,MySQL开发基础 6.1 MySQL数据库系统介绍及安装;6.2 MySQL数据类型介绍; 6.3 MySQL表的创建、修改与删除;6.4 MySQL查询语句;6.5 PHP MySQL函数使用详解。 实例:1,论坛数据库表设计; 2,PHP连接MySQL数据库,实现增删改查。第七讲,Web2.0开发技术Ajax 7.1 JavaScript介绍;7.2 JavaScript语法基础; 7.3 DOM对象基础及事件;7.4 Ajax核心对象XMLHttpRequest详解;7.5 Ajax异步通信原理;7.6 开发Ajax应用;7.6 Ajax框架jQuery介绍及使用。 实例:1,Tab的动态切换效果; 2,论坛系统中使用Ajax方式验证用户名是否被注册;3,论坛系统中通过Ajax方式获取用户信息。第八讲,PHP Web2.0网站实例开发 8.1 Web2.0风格的论坛系统开发;8.2 Web2.0风格的博客系统实战开发。 实例:1,综合DIV+CSS +PHP+MySQL+Ajax技术开发论坛; 2,综合DIV+CSS +PHP+MySQL+Ajax技术开发博客系统。 第二阶段第一讲,PHP面向对象基础 1.1 面向对象编程介绍;1.2 面向过程与面向对象的区别; 1.3 面向对象的基本特性;1.4 类、属性和方法;1.5 构造函数;1.6 类的实例化;1.7 使用类的属性和方法;1.8 类的访问控制;1.9 类的继承与多态;1.10 面向对象的接口及抽象类;1.11 类、对象及对象之间的关系;1.12 几个常见的运算符和关键字。 实例:1,购物车对象关系设计; 2,班级、学生、课程、考试对象关系设计。第二讲,PHP模板技术Smarty框架 2.1 Smarty模板技术介绍;2.2 Smarty安装与配置; 2.3 Smarty 变量与变量修饰符;2.4 Smarty分支结构;2.5 Smarty循环......余下全文>>
 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/840632.htmlTechArticlephp事务处理实例详解,php事务处理详解 一、php事务处理概述: 事务: 是若干事件的集合 事务处理: 当所有事件执行成功,事务才执行;若有任...
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何使PHP应用程序更快如何使PHP应用程序更快May 12, 2025 am 12:12 AM

tomakephpapplicationsfaster,关注台词:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

PHP中的依赖注入:一个简单的解释PHP中的依赖注入:一个简单的解释May 10, 2025 am 12:08 AM

依赖性(di)inphpenhancesCodeFlexibility andTestability by decouplingClassesscyclasses fromtheippentencies.1)UseConstructorientoctionTopAssDopassDectiesViactructors Viactructors

PHP DI容器比较:选择哪一个?PHP DI容器比较:选择哪一个?May 10, 2025 am 12:07 AM

推荐Pimple用于简单项目,Symfony的DependencyInjection用于复杂项目。1)Pimple适合小型项目,因其简单和灵活。2)Symfony的DependencyInjection适合大型项目,因其功能强大。选择时需考虑项目规模、性能需求和学习曲线。

PHP依赖注入:什么,为什么以及如何?PHP依赖注入:什么,为什么以及如何?May 10, 2025 am 12:06 AM

依赖性注射(DI)InphpisadesignpatternwhereClassDepentenciesArepassedtotosedTosedTosedTotratherThancReateDinterally,增强codemodemodularityAndTestabily.itimprovessoftwarequalitybyby By:1)增强tosestabilityTestabilityTestabilityThroughityThroughEasyDepentyDepententymydependentymocking,2)增强Flexibilybya

PHP中的依赖注入:最终指南PHP中的依赖注入:最终指南May 10, 2025 am 12:06 AM

依赖性(di)InphpenhancesCodemodularity,可检验性和确定性。1)itallowSeasysWappingOfComponents,AsseeninaPaymentGateWayswitch.2)dicanbeimimplementlededMermplemplemplemplemplemplemplemplemplempletallyororororerorviacontainers,withcontanersAddingComplexiteDcomplexiteDcomplexiteDcomplexitingCompleaDdingCompleAddingButaidLararArargerProprproproprys.3)

优化PHP代码:减少内存使用和执行时间优化PHP代码:减少内存使用和执行时间May 10, 2025 am 12:04 AM

TOOPTIMIZEPHPCODEFORDUSEMEMORYUSAGEAGEAGEAGEAGEAGEANDEXECUTITIEM,关注台词:1)USEREEREFERESCENCENCINCOPYINSTEADOFCOPYINGINATATASTRUCTURESTROUCTURESTOREDUCEMORYCONSUMPTION.2)杠杆phphppphpphp'sbuilt intimpunctionslikearray_mapforfunctionslikearray_mapforfforfforfforfasterapasterexecution.3)

PHP电子邮件:分步发送指南PHP电子邮件:分步发送指南May 09, 2025 am 12:14 AM

phpisusedforsendendemailsduetoitsignegrationwithservermailservicesand andexternalsmtpproviders,自动化notifications andMarketingCampaigns.1)设置设置yourphpenvironcormentswironmentswithaweberswithawebserverserverserverandphp,确保themailfunctionisenabled.2)useabasicscruct

如何通过PHP发送电子邮件:示例和代码如何通过PHP发送电子邮件:示例和代码May 09, 2025 am 12:13 AM

发送电子邮件的最佳方法是使用PHPMailer库。1)使用mail()函数简单但不可靠,可能导致邮件进入垃圾邮件或无法送达。2)PHPMailer提供更好的控制和可靠性,支持HTML邮件、附件和SMTP认证。3)确保正确配置SMTP设置并使用加密(如STARTTLS或SSL/TLS)以增强安全性。4)对于大量邮件,考虑使用邮件队列系统来优化性能。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境