0

我有这个登录系统:

    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 并再次重新编写代码(针对该版本的新功能)。

更新:

和数据库连接:

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;

        }
    }
4

1 回答 1

0

当您仍在测量连接与执行时间时,我将冒险猜测答案。我认为您的连接时间是导致延迟的原因。查看之前提出的类似问题。 https://serverfault.com/questions/408550/connecting-to-mysql-from-php-is-extremely-slow

关闭反向 DNS 查找可能会对您有所帮助。添加一个链接,显示如何将其关闭:

http://developers.sugarcrm.com/wordpress/2012/01/10/howto-turn-off-mysql-reverse-dns-lookup-to-speed-up-response-times/

于 2013-02-13T01:32:12.463 回答