我在MacOSX Lion上进行了自定义安装,包括以下内容:
在/ etc /中编辑php.ini以激活以下内容:
extension=php_mysqli.so
extension=php_pdo_pgsql.so
extension=php_pdo_mysql.so
phpinfo()说明如下:
PDO
启用PDO支持 PDO驱动程序mysql,pgsql,sqlite
PDO_MYSQL
启用了MySQL的PDO驱动程序 客户端API版本mysqlnd 5.0.10 - 20111026 - $ Id:b0b3b15c693b7f6aeb3aa66b646fee339f175e39 $
指令本地价值主值 pdo_mysql.default_socket /var/mysql/mysql.sock /var/mysql/mysql.sock
这意味着它有效,是吗?
但有两个问题:
没有/var/mysql/mysql.sock这样的文件,它位于/tmp/mysql.sock中。但我使用PDO选项配置和构建php: - with-mysql = mysqlnd --with-mysqli = mysqlnd --without-pear --with-pdo-mysql = mysqlnd --with-mysql-sock = / var /mysql/mysql.sock。如果我将ini设置更改为/tmp/mysql.sock没有效果,它会反映在php.ini中,但错误保持完全相同。
当我尝试在PHP中实例化PDO类时,会发生这种情况: 未捕获的异常'PDOException',消息'找不到驱动程序'
当我尝试以旧式的mysqli方式从PHP访问MySQL时,我得到了这个:
无法连接到MySQL:(2002)没有这样的文件或目录警告:main():无法获取mysqli ...
我还可以尝试使我的PHP和MySQL运行得更好吗?
答案 0 :(得分:6)
解决方案是执行以下操作:
执行
时,似乎没有加载php.ini更改$ sudo apachectl restart
并且需要Macbook重新启动才能将它们考虑在内。