我有这个登录系统:
require_once "conexion.php";
class login extends conexion {
public function log_user($user,$pass)
{
$conexion = mysql_conexion();
$login = "SELECT user_name,user_pass,id FROM menssager_user WHERE user_name='$user' AND user_pass='$pass'";
$e = $conexion->prepare($login);
$e->execute();
$re = $e->fetch(PDO::FETCH_ASSOC);
if($user == $re["user_name"] && $pass == $re["user_pass"])
{
$this->is_online($re["id"]);
return $re["id"];
}
$conexion = null;
} }
当我执行该代码时,需要1.3秒才能确定该用户是否存在,并且我在数据库中只有2个用户名。 有人能告诉我为什么这么慢? 注意:昨天我升级到5.4.7并重新编写代码(对于该版本的新功能)。
更新
数据库conexion:
class conexion{
public function mysql_conexion(){
$conexion_path = "mysql:dbname=menssager;host:127.0.0.1";
$root = "root";
$pass = "";
try{
$conectar = new PDO($conexion_path,$root,$pass);
$conectar->setAttribute(PDO::ATTR_EMULATE_PREPARES,false);
$conectar->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}catch(PDOException $error)
{
echo $conectar = $error->getMessage();
}
return $conectar;
}
}
答案 0 :(得分:0)
当你还在测量连接与执行时间时,我会猜测答案。我认为你的连接时间是导致延迟的原因。看看前面提到过的类似问题。 https://serverfault.com/questions/408550/connecting-to-mysql-from-php-is-extremely-slow
关闭反向DNS查找可能会对您有所帮助。 添加一个链接,显示如何关闭它: