PHP   发布时间:2022-04-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了如何在PHP中处理查询同步?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

我想在一个表中插入一些值,该表具有一个自动递增字段作为主键.然后,我想通过使mysql_insert_id()检索ID并将此ID用作另一个表中的外键.问题是-尽管可能性很小-在第一次插入和以后的检索之间可能会发生另一次插入到第一个表中,因此将返回错误的ID.

PHP是否会自动处理此问题,还是我的担忧有效?如果是这样,我该如何克服它们?

解决方法:

MysqL_insert_id()将基于每个连接返回最后插入的id.因此,基本上,您不必担心并发脚本请求.

供参see the MySQL docs.

编辑:

便说一句,您可以很容易地对此进行测试.

test.PHP

<?PHP

    $sleep = isset( $_GET[ 'sleep' ] ) ? true : false;

    $conn = MysqL_connect( /* your parameters */ );
    MysqL_SELEct_db( /* your db */, $conn );

    $sql = 'INSERT INTO yourtable(id,col1,col2) VALUES(null,"test","test")';
    MysqL_query( $sql );

    if( $sleep ) sleep( 5 );

    echo MysqL_insert_id();
?>

打开两个浏览器标签

首先要求:
http://localhost/test.php?sleep=1

请在第二秒内(例如,最多4秒)内请求:
http://localhost/test.php

一个请求应该给您的ID少于第二个请求.

大佬总结

以上是大佬教程为你收集整理的如何在PHP中处理查询同步?全部内容,希望文章能够帮你解决如何在PHP中处理查询同步?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: