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

Posted ai10999

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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);

来自微信公众号:编程社

技术图片

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

以上是关于PHP应对并发,MySQL数据库防止数据不一致的主要内容,如果未能解决你的问题,请参考以下文章

数据库与缓存一致性问题解决方案

Mysql和Redis数据同步策略

MySQL的读写分离与主从同步数据一致性

PHP使用文件排它锁,应对小型并发

MySQL行级锁和表级锁

应对Memcache缓存失效,导致高并发查询DB