Устранение неполадок "Нет такого файла или каталога" при запуске `php app / console doctrine: schema: create` - PullRequest
36 голосов
/ 07 июня 2011

Я новичок в Symfony2 (бета4) и Doctrine, и у меня возникают проблемы при попытке создать схему БД через командную строку.

Вот ошибка:

$ php app/console doctrine:schema:create

Creating database schema...

[PDOException]                                    
SQLSTATE[HY000] [2002] No such file or directory  

[ErrorException]                                                                                          
Warning: PDO::__construct(): [2002] No such file or directory (trying to connect via unix:///var/mysql/mysql.sock) 
in /Applications/MAMP/htdocs/sf-test-2/vendor/doctrine-dbal/lib/Doctrine/DBAL/Driver/PDOConnection.php line 36

Настройки базы данных mysql правильно вставлены в файл config / parameters.ini.

А вот конфигурация Doctrine в config.yml

# Doctrine Configuration
doctrine:
    dbal:
        driver:   %database_driver%
        host:     %database_host%
        dbname:   %database_name%
        user:     %database_user%
        password: %database_password%

    orm:
        auto_generate_proxy_classes: %kernel.debug%
        auto_mapping: true

И сущность (я сделал только один, чтобы проверить это)

<?php
// src/Acme/NewsBundle/Entity/Article.php
namespace Acme\NewsBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\Entity
 * @ORM\Table(name="articles")
 */
class Article
{
    /**
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
protected $id;

/**
 * @ORM\Column(type="string", length="255")
 */
protected $title;

/**
 * @ORM\Column(type="text")
 */
protected $body;

/**
 * @ORM\Column(type="string", length="255")
 */
protected $author;

/**
 * @ORM\Column(type="date")
 */
protected $date;
}
?>

Ответы [ 12 ]

0 голосов
/ 12 августа 2016

Стоит проверить, работает ли Mysql тоже.

0 голосов
/ 07 ноября 2014

Иногда вы можете получить несколько решений для пути к местоположению mysql.lock. Но я думаю, что лучшее решение - просто увидеть путь к местоположению mysql с помощью функции php phpinfo().

Примечание: если вы не знакомы с phpinfo(), просто создайте файл, дайте любое имя и включите содержимое этого файла, например,

<?php
phpinfo();
?>

запустите этот файл и получите путь к файлу mysql.lock. Я думаю, что это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...