我试图连接到我的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 EL Capitan + MAMP Pro 这样做

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

然后这样做

cd /tmp
sudo ln -s /Applications/MAMP/tmp/mysql/mysql.sock 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服务

修复了即将出现的2002套接字错误——这是连接MySQL放置套接字的地方和OSX认为它应该在的地方,MySQL把它放在/tmp中,OSX在/var/ MySQL中寻找它,套接字是一种允许MySQL客户端/服务器通信的文件类型。

sudo mkdir /var/mysql

然后

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

来源:http://coolestguidesontheplanet.com/get-apache-mysql-php-phpmyadmin-working-osx-10-10-yosemite/

mySQL客户端默认尝试通过一个称为套接字的本地文件进行连接,而不是连接到本地主机的环回地址(127.0.0.1)。

至少在OSX上,这个套接字文件的默认位置是/tmp/mysql.sock。

快速,不那么优雅的解决方案

创建一个符号链接来欺骗操作系统找到正确的套接字。

ln -s /Applications/MAMP/tmp/mysql/mysql.sock /tmp

妥善解决

修改/Applications/MAMP/bin目录下startMysql.sh文件中定义的套接字路径。

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

我也遇到过同样的问题,我是这样解决的:

我有这个,但不管用:

$con = mysql_connect('localhost', 'root', '1234');

我这样做了,效果很好:

$con = mysql_connect(':/Applications/MAMP/tmp/mysql/mysql.sock', 'root', '1234');

我没有使用mysql服务器,而是直接连接到Unix Socket。为我工作。