我试图连接到我的MySQL数据库与终端在我的苹果(与PHP)。

昨天它工作正常,现在我突然得到错误的标题。

当我使用浏览器运行该脚本时(我已经安装了XAMPP),但终端拒绝连接到DB。

下面是我要连接的文件(当我不包括这个时,脚本工作,但它不连接到DB):

<?php
    mysql_connect("localhost", "root", "") or die(mysql_error());
    mysql_select_db("FNB1C_data") or die(mysql_error());
?>

这应该可以工作,因为它适用于我的浏览器。

我在终端上使用的命令是php scriptname.php。


当前回答

MySQL套接字通常位于/tmp/ MySQL中。Sock或/var/mysql/mysql. Socksock,但可能PHP看起来在错误的地方。

Check where is your socket with: sudo /usr/libexec/locate.updatedb When the updatedb is terminated: locate mysql.sock Then locate your php.ini: php -i | grep php.ini this will output something like: Configuration File (php.ini) Path => /opt/local/etc/php54 Loaded Configuration File => /opt/local/etc/php54/php.ini Edit your php.ini sudo vim /opt/local/etc/php54/php.ini Change the lines: pdo_mysql.default_socket=/tmp/mysql.sock mysql.default_socket=/tmp/mysql.sock mysqli.default_socket = /tmp/mysql.sock where /tmp/mysql.sock is the path to your socket. Save your modifications and exit ESC + SHIFT: x Restart Apache sudo apachectl stop sudo apachectl start

其他回答

MySQL套接字通常位于/tmp/ MySQL中。Sock或/var/mysql/mysql. Socksock,但可能PHP看起来在错误的地方。

Check where is your socket with: sudo /usr/libexec/locate.updatedb When the updatedb is terminated: locate mysql.sock Then locate your php.ini: php -i | grep php.ini this will output something like: Configuration File (php.ini) Path => /opt/local/etc/php54 Loaded Configuration File => /opt/local/etc/php54/php.ini Edit your php.ini sudo vim /opt/local/etc/php54/php.ini Change the lines: pdo_mysql.default_socket=/tmp/mysql.sock mysql.default_socket=/tmp/mysql.sock mysqli.default_socket = /tmp/mysql.sock where /tmp/mysql.sock is the path to your socket. Save your modifications and exit ESC + SHIFT: x Restart Apache sudo apachectl stop sudo apachectl start

另一个解决方案是修复php.ini配置文件中的套接字位置,就像这样:

pdo_mysql.default_socket=/tmp/mysql.sock

当然,符号链接也可以工作,所以这是一个你改变的偏好问题。

原因是php无法找到mysql.sock的正确路径。

请确保您的mysql首先运行。

然后,请确认哪个路径是mysql。Sock,例如/tmp/mysql.sock

然后将这个路径字符串添加到php.ini:

Mysql.default_socket = /tmp/mysql.sock Mysqli.default_socket = /tmp/mysql.sock Pdo_mysql.default_socket = /tmp/mysql.sock

最后,重新启动Apache。

我也有这个错误,但只能通过这里的建议来修复。

总结一下,用:

127.0.0.1

而不是:

localhost

原因是“localhost”是MySQL驱动程序的一个特殊名称,它使用UNIX套接字来连接MySQL,而不是TCP套接字。

我得到了同样的错误。 在我启动phpMyAdmin之前,Mysql是作为一个独立的应用程序运行的。

我停止了mysql 然后 sudo /Applications/XAMPP/xamppfiles/ XAMPP stop sudo /Applications/XAMPP/xamppfiles/ XAMPP start

它运行得很好