我正在使用PDO连接到mySql数据库。 我无法连接到我创建的任何数据库,尽管我可以连接到已经创建的数据库(默认情况下已经创建)。 我用的是wamp服务器。
<?php
try{
$dbh=new PDO("mysql:host=localhost;dbname=mydata","root","");
}catch(Exception $e){
die("ERROR: Couldn't connect. {$e->getMessage()}");
}
?>
如果我用以前在wamp服务器中创建的数据库mysql替换mydata,那么代码可以完美地工作。 唯一的问题是我创建的数据库。 我试过赋予mydata与mysql数据库相同的权限,但它不起作用。
您的PC上有多个数据库服务器在运行,您的代码和phpmyadmin连接到不同的数据库
要获得证明,请在phpMyAdmin中运行以下查询:
show databases;
然后在PDO中运行相同的查询:
$host = 'your db host';
$user = 'your db username';
$pass = 'your db password';
$pdo = new PDO("mysql:host=$host", $user, $pass, [PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION]);
$databases = $pdo->query('show databases')->fetchAll(PDO::FETCH_COLUMN);
var_dump($databases);
或mysqli
$host = 'your db host';
$user = 'your db username';
$pass = 'your db password';
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$mysqli = mysqli_connect($host, $user, $pass);
$databases = $mysqli->query('show databases')->fetch_all();
var_dump($databases);
并比较输出。 它将向您显示,要么存在拼写错误,要么确实是phpmyadmin和PHP连接到了不同的数据库服务器。
然后您可以检查PHPmyAdmin中的配置文件,以确保它连接到正确的服务器
这样试试
更改host=localhost; 至主机=127.0.0.1;