无法在CakePHP中使用MySQL

这是我第一次安装框架,我很无能为力.

我在OSX 10.7上,我将cakephp框架加载到/ Library / WebServer / Documents / cakephp中,我已经能够加载测试页面并摆脱一些错误和警告.现在我正在努力解决这个问题

  Warning (2): PDO::__construct() [pdo.--construct]: [2002] No such file or directory (trying to connect via unix:///var/mysql/mysql.sock) [CORE/Cake/Model/Datasource/Database/Mysql.php, line 160]
  Cake is NOT able to connect to the database.
  Database connection "SQLSTATE[HY000] [2002] No such file or directory" is missing, or could not be created.

我真的不知道该怎么做.我已经安装了MySQL. MySQL PDO是否默认安装在OSX上?或者我需要安装吗?如果这似乎是问题,我该如何检查是否已安装.

更新:

PDO Mysql驱动程序已启用.
pro_mysql的phpinfo()也是这样的:

 Directive                     Local Value               Master Value
 pdo_mysql.default_socket   /var/mysql/mysql.sock   /var/mysql/mysql.sock 

但是mysql目录没有出现在我的文件系统中.我应该创建它吗?或者我是否需要在某处改变这条路?

更新:
我认为问题是我实际上没有建立数据库.我愚蠢的是不要设置数据库.

我想我现在会尝试解决这个问题.

更新:

最终解决这个问题的是,蛋糕正在寻找/var/mysql/mysql.sock中数据库的Unix套接字但是mysql正在使用/tmp/mysql.sock中的套接字
我通过创建从/var/mysql/mysql.sock到/tmp/mysql.sock的符号链接来修复此问题.

最佳答案 它看起来更像是MySQL本身没有安装,但是PDO库是用你的web服务器编译的.我不知道如何在OSX中检查这个,但你可以尝试检查这个链接:
http://www.sequelpro.com/docs/Install_MySQL_on_Mac_OS_X

编辑

登录MySQL(mysql -u root -p)并创建数据库:

create database cakephp

然后创建一个新的用户名/密码并授予他们访问该数据库的权限.假设您要创建用户名cakephp和密码cakepass:

GRANT ALL ON cakephp.* TO cakephp@localhost IDENTIFIED BY 'cakepass';
FLUSH PRIVILEGES;

现在你的database.php配置文件应如下所示:

<?php
class DATABASE_CONFIG {
    public $default = array(
        'datasource'  => 'Database/Mysql',
        'persistent'  => false,
        'host'        => 'localhost',
        'login'       => 'cakephp',
        'password'    => 'cakepass',
        'database'    => 'cakephp',
        'prefix'      => ''
    );
}
点赞