需要注意的是,mysql_ping() 似乎重置了服务器上的错误消息。
我用它来检查连接是否仍然有效,然后再通过 mysql_error() 读取错误消息,它始终返回空字符串。删除连接检查后,一切正常。
(PHP 4 >= 4.3.0,PHP 5)
mysql_ping — Ping 服务器连接或在没有连接时重新连接
此扩展在 PHP 5.5.0 中已弃用,并在 PHP 7.0.0 中删除。应改用 MySQLi 或 PDO_MySQL 扩展。另请参阅 MySQL:选择 API 指南。此函数的替代方案包括
检查与服务器的连接是否正常工作。如果连接已断开,则会尝试自动重新连接。此函数可由长时间处于空闲状态的脚本使用,以检查服务器是否已关闭连接并在必要时重新连接。
注意:
在 MySQL >= 5.0.3 的版本中,默认情况下禁用自动重新连接。
link_identifier
MySQL 连接。如果未指定链接标识符,则假定为 mysql_connect() 最近打开的链接。如果找不到此类链接,它将尝试创建一个链接,就像 mysql_connect() 已被调用且没有参数一样。如果找不到或建立连接,则会生成 E_WARNING
级别错误。
示例 #1 mysql_ping() 示例
<?php
set_time_limit(0);
$conn = mysql_connect('localhost', 'mysqluser', 'mypass');
$db = mysql_select_db('mydb');
/* 假设此查询将花费很长时间 */
$result = mysql_query($sql);
if (!$result) {
echo '查询 #1 失败,退出。';
exit;
}
/* 确保连接仍然有效,如果不是,尝试重新连接 */
if (!mysql_ping($conn)) {
echo '连接已断开,查询 #1 后退出';
exit;
}
mysql_free_result($result);
/* 因此连接仍然有效,让我们运行另一个查询 */
$result2 = mysql_query($sql2);
?>
需要注意的是,mysql_ping() 似乎重置了服务器上的错误消息。
我用它来检查连接是否仍然有效,然后再通过 mysql_error() 读取错误消息,它始终返回空字符串。删除连接检查后,一切正常。
当您遇到此烦人的错误时,mysql_ping() 非常有用
MYSQL 错误 2006 服务器已断开
对于 CI 用户
在 CodeIgniter 的 1.7.2 版本中,有一个函数
$this->db->reconnect()
它使用 mysql_ping() 来重新建立超时连接。
此函数在开发使用数百个数据库连接(如插入或选择)的社交媒体网站时特别有用。
在检查 $resource 是否有效时...
请准备好,只要 $resource 不是正确的 mysql 资源,mysql_ping 就会返回 NULL。
<?php
$resource =NULL;
var_dump = @mysql_ping($resource);
# 显示 NULL
?>
这可用于确定当前 $resource 是 mysql 连接还是 mysqli 连接,而没有其他可用方法来做到这一点...
在 PHP 5.1.2 和 MySQL 5.0 下使用 mysql_ping 命令时,我遇到了自动重新连接“功能”的问题,主要是当连接断开时,mysql_ping 不会自动重新建立与数据库的连接。
当没有查询的时间超过 my.cnf 中的 wait_timeout 值时,与数据库的连接将断开。您可以通过运行查询“SHOW VARIABLES;”来检查您的 wait_timeout。
如果您在连接断开时遇到自动重新连接的问题,请使用此代码
<?php
$conn = mysql_connect('localhost','user','pass');
mysql_select_db('db',$conn);
if (!mysql_ping ($conn)) {
//这里的关键技巧是,您必须关闭连接(即使它当前无法工作),才能使其正确重新创建。
mysql_close($conn);
$conn = mysql_connect('localhost','user','pass');
mysql_select_db('db',$conn);
}
//运行查询,确保连接处于活动状态....
?>
需要注意的是,如果您的第一次 MySQL 连接失败,mysql_ping 将始终返回 true!因此,如果您想检查是否已连接到 MySQL,首先必须检查 mysql_connect 是否未返回 false,然后才能开始检查 mysql_ping。