douyin4561 2014-03-19 10:14
浏览 56
已采纳

无法通过PHP PDO类连接到数据库

I'm trying to connect to my mySQL database using the PDO class in PHP.

Here is my Code :

// Connects to Our Database via PDO.
if($local) {
    try {
        $db = new PDO("mysql:=localhost;dbname=bbc_archive;port=3306", "root", "");
        $db->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
        $db->exec("SET NAMES 'utf8'");
        } catch(Exception $e) {
            echo "Connection to the DataBase was not possible. ";
            die();
        }
    } else {
    try {
        $db = new PDO("mysql:=bbcarchive.db.11505263.hostedresource.com;dbname=bbcarchive", "bbcarchive", "myPassword");
        $db->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
        $db->exec("SET NAMES 'utf8'");
    } catch(Exception $e) {
        echo "Connection to the live DataBase was not possible. ";
        die();
    }
}

The $local variable is defined before and determines whether or not the script is running on a the live server or a test server.

When running in my local environment everthing works fine but on my live server it echo's out "Connection to the live DataBase was not possible." from the catch block.

I've contacted my host provider (godaddy) and they think it's a coding error. I've also, obviously, checked the hostname, dbname, username and password a 100 times and it's all correct. I just can't see the problem!

How can i do this ?

  • 写回答

1条回答 默认 最新

  • duancai9010 2014-03-19 10:18
    关注

    Your DSN seems to be incorrect. The documentation on MySQL DSNs indicates that it should look somewhat like this:

    $db = new PDO("mysql:host=localhost;dbname=bbc_archive;port=3306", "root", "");
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大