随笔 - 144  文章 - 0  评论 - 2  阅读 - 19万

PHP应对并发,MySQL数据库防止数据不一致

分析:

PHP本身是单线程语言,所以在应对并发的程序语言层面上面没有比较好的解决方案,不过可以借助其他设计来实现,例如基于MySQL的Innodb引擎下数据库本身的行锁实现,或者依靠Redis等队列存储来实现。这里来讲解一下基于MySQL的行锁的实现方式。

 

注意:

只有基于Innodb的引擎才支持数据库事务行锁,如果在实际操作过程中,执行不成功,请检查表引擎是否正确。另外行锁依靠数据事务提交而提交。

 

程序代码:

复制代码
$conn = mysql_connect('127.0.0.1', 'root', 'root') or die(mysql_error()); //链接MySQL

mysql_select_db($conn, 'student'); //选择数据库

mysql_query($conn, 'BEGIN'); //开启事务

//执行下面这条语句后,username="张三"的行将会在事务提交了之后才能被别的进程访问
$res = mysql_query($conn, 'SELECT * FROM user WHERE username = "张三" FOR UPDATE'); 

$row = mysql_fetch_array($res); //获取结果集

mysql_query($conn, "update user set username='李四' where username='张三'");//重新更新数据

mysql_query($conn, 'COMMIT'); //提交事务

mysql_free_result($res); 
mysql_close($conn);
复制代码

来自微信公众号:编程社

程序员日常进阶宝典,欢迎关注!

posted on   黑夜开发者  阅读(628)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示