PHP 多个mysql连接的问题
程序员文章站
2022-03-28 08:07:21
...
今天在同一个php进程中用mysql_connect新建了两个mysql句柄,这两个句柄都连接同一台数据库,只不过操作的数据库dbname不同,假设这两个句柄分别是$dbhA和$dbhB,它们对应的数据库dbname分别是dbA和dbB。我在$dbhA上操作dbA中的时候缺报错是dbB中没有表xxx。
今天在同一个php进程中用mysql_connect新建了两个mysql句柄,这两个句柄都连接同一台数据库,只不过操作的数据库dbname不同,假设这两个句柄分别是$dbhA和$dbhB,它们对应的数据库dbname分别是dbA和dbB。我在$dbhA上操作dbA中的时候缺报错是dbB中没有表xxx。。。
起初以为是我应用层逻辑处理在某个地方弄混了两个句柄,翻半天没翻出来,后来在这里发现了同样的问题。
原来是mysql_connect的实现中,如果再次调用它时操作的是同一个数据库,那么会返回第一次调用mysql_connect返回的那个句柄。所以在同一个PHP进程中对同一个数据库创建多个连接时,应该这么搞:
$db1 = mysql_connect($host1, $user1, $passwd1, true); $db2 = mysql_connect($host2, $user2, $passwd2, true);
http://php.net/manual/zh/function.mysql-connect.php 这里有对第四个参数的详细解释:
如果用同样的参数第二次调用 mysql_connect(),将不会建立新连接,而将返回已经打开的连接标识。参数new_link
改变此行为并使 mysql_connect() 总是打开新的连接,甚至当 mysql_connect() 曾在前面被用同样的参数调用过。
推荐阅读
-
PHP使用empty检查函数返回结果时报Fatal error: Can't use function return value in write context的问题 - 心中的飞梦
-
Mysql无法初始化字符集的问题
-
CSV文件导入mysql PHP处理CSV表格文件的常用操作方法总结
-
如何解决 PHP 第一次连接Oracle非常慢的问题
-
php字符转码解决新浪抓取资料乱码的问题
-
php调用多个存储过程时,怎么让连接不关闭。
-
写了一个连接数据库的通用类,SQL语句执行有有关问题
-
程序员 - PHP时间问题,2014-1-21 和 2013-5-13 请用最有效率的方法计算出两个时间相差的年份和月份??
-
关于STR REPLACE 不能替换多个字符的有关问题 求解
-
select-MySQL中触发器的创建问题