我试图连接到我的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。


当前回答

我使用的是Mac OS X上的XAMPP,上面Brian Lowe的解决方案只需要稍加修改就能工作。

mysql。sock文件实际上在“/Applications/xampp/xamppfiles/var/mysql/”文件夹中。所以必须在/tmp和/var/mysql中链接它我还没有检查哪一个被PHP命令行使用,但这做了修复,所以我很高兴:-)

sudo su
ln -s /Applications/xampp/xamppfiles/var/mysql/mysql.sock /tmp/mysql.sock
mkdir /var/mysql
ln -s /Applications/xampp/xamppfiles/var/mysql/mysql.sock /var/mysql/mysql.sock

其他回答

当你面临以下问题时:

PHP抛出错误“警告:mysql_connect() http://function.mysql-connect: 2002没有这样的文件或目录(试图通过unix:///tmp/mysql.sock连接)”

在/etc/php.ini中设置“mysql.default_socket”的值为

 "mysql.default_socket = /var/mysql/mysql.sock". 

然后在服务器管理中重新启动web服务

原因是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。

当你使用port安装php53-mysql时,它会返回以下消息,这是这个问题的解决方案:

To use mysqlnd with a local MySQL server, edit /opt/local/etc/php53/php.ini
and set mysql.default_socket, mysqli.default_socket and
pdo_mysql.default_socket to the path to your MySQL server's socket file.

For mysql5, use /opt/local/var/run/mysql5/mysqld.sock
For mysql51, use /opt/local/var/run/mysql51/mysqld.sock
For mysql55, use /opt/local/var/run/mysql55/mysqld.sock
For mariadb, use /opt/local/var/run/mariadb/mysqld.sock
For percona, use /opt/local/var/run/percona/mysqld.sock

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

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

它运行得很好

由于某些原因,OS X上的mysql获取所需套接字文件的位置有点错误,但幸运的是,解决方案非常简单,只需设置一个符号链接。

你可能有一个套接字(显示为零长度文件)作为/tmp/mysql。Sock或/var/mysql/mysql. SockSock,但是一个或多个应用程序正在其他位置寻找它。用这个命令找出答案:

ls -l /tmp/mysql.sock /var/mysql/mysql.sock

而不是移动套接字,编辑配置文件,并必须记住将编辑的文件保存在本地,远离路径正确的服务器,只需创建一个符号链接,以便您的Mac找到所需的套接字,即使它在错误的地方查找!

如果你有/tmp/mysql。Sock,但没有/var/mysql/mysql袜子然后……

cd /var 
sudo mkdir mysql
sudo chmod 755 mysql
cd mysql
sudo ln -s /tmp/mysql.sock mysql.sock

如果你有/var/mysql/mysql.没有/tmp/mysql。袜子然后……

cd /tmp
ln -s /var/mysql/mysql.sock mysql.sock

您将需要权限来创建目录和链接,因此如果需要,只需在上面的命令前面加上sudo即可。