博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php+mysql事务处理例子详细分析实例
阅读量:6552 次
发布时间:2019-06-24

本文共 1209 字,大约阅读时间需要 4 分钟。

一、数据引擎innodb用begin,rollback,commit来实现提交事务处理,begin开始事务后出现错误就rollback事务回滚或者没有错误就commit提事务提交确认完成。
  start transaction 开始是事务begin和end之间是执行的语句块,set autocommit=0不让事务自动提交设置后要在结束set autocommit=1。
  下面是针对支持事务处理的数据表引擎例子。
mysql_query("start transaction");mysql_query("set autocommit=0");mysql_query("begin"); $sql = "insert into student ( name,num) values ( 'test1', '0')";$sql2 = "insert into student ( name,num) values ( null, '0')";//写错$res = mysql_query($sql);$res1 = mysql_query($sql2); if($res && $res1){    mysql_query("commit");    echo '提交成功。
';}else{ mysql_query("rollback"); echo '数据回滚。
';}mysql_query("set autocommit=1");mysql_query("end");

二、对于不支持事务的MyISAM引擎数据库可以使用表锁定的方法:

  MyISAM & InnoDB 都支持,LOCK TABLES可以锁定用于当前线程的表。如果表被其它线程锁定,则造成堵塞,直到可以获取所有锁定为止。UNLOCK TABLES可以释放被当前线程保持的任何锁定。当线程发布另一个LOCK TABLES时,或当与服务器的连接被关闭时,所有由当前线程锁定的表被隐含地解锁。
  下面例子是针对不支持事务提交而使用表锁的例子

mysql_query("lock tables student write");//锁住student表write 也可以是read$sql = "insert into student ( name,num) values ( '三生三世', '0')";$res = mysql_query($sql);if($res){    echo '提交成功。!
';}else{ echo '失败!
';}mysql_query("UNLOCK TABLES");//解除锁定

上面代码完整的实例下载地址:http://pan.baidu.com/s/1pLkbkKj

密码:bh49

转载于:https://www.cnblogs.com/sztx/p/9499764.html

你可能感兴趣的文章
2016-2017 ACM-ICPC Southwestern European Regional Programming Contest (SWERC 2016)
查看>>
简明 MongoDB 入门教程
查看>>
.NET Core 3.0中的数据库驱动框架System.Data
查看>>
北大AI公开课2019 | 雷鸣:人工智能革命与机遇
查看>>
英特尔开源计算机视觉数据标签工具CVAT,加速数据注释
查看>>
SQL Server内存泄漏
查看>>
NoSQL生态系统——一致性RWN协议,向量时钟,gossip协议监测故障
查看>>
用Windows Live Writer发布日志到BlogBus
查看>>
解决公司服务器加入域中不能启动应用系统的问题
查看>>
解压缩 操作
查看>>
rsyslog收集nginx日志配置
查看>>
如何判断各种手机浏览器?
查看>>
consule服务注册和发现 安装 部署
查看>>
多个帐户都用root 来登录 怎么看另一个用户使用的那些命令
查看>>
Redis小记
查看>>
Map集合案例
查看>>
《FPGA全程进阶---实战演练》第十一章 VGA五彩缤纷
查看>>
C# for循环①护栏长度 ②广场砖面积 ③判断闰年平年
查看>>
mysql数据库中,查看数据库的字符集(所有库的字符集或者某个特定库的字符集)...
查看>>
LintCode刷题——打劫房屋I、II、III
查看>>