Php Проблема с соединением (SQL STATE 2002) с MySQL при правильной строке подключения - PullRequest
1 голос
/ 13 апреля 2020

Я не могу сменить схему sh на терминал MySQL DB.

Я всегда получаю ошибку 2002 года.

enter image description here

Я установил MySQL. Он работает и работает.

Я использую MAMP.

Вот мой файл .env

# In all environments, the following files are loaded if they exist,
# the latter taking precedence over the former:
#
#  * .env                contains default values for the environment variables needed by the app
#  * .env.local          uncommitted file with local overrides
#  * .env.$APP_ENV       committed environment-specific defaults
#  * .env.$APP_ENV.local uncommitted environment-specific overrides
#
# Real environment variables win over .env files.
#
# DO NOT DEFINE PRODUCTION SECRETS IN THIS FILE NOR IN ANY OTHER COMMITTED FILES.
#
# Run "composer dump-env prod" to compile .env files for production use (requires symfony/flex >=1.2).
# https://symfony.com/doc/current/best_practices.html#use-environment-variables-for-infrastructure-configuration

###> symfony/framework-bundle ###
APP_ENV=dev
APP_SECRET=f492b5be321d353dbb48352876d4db75
#TRUSTED_PROXIES=127.0.0.0/8,10.0.0.0/8,172.16.0.0/12,192.168.0.0/16
#TRUSTED_HOSTS='^(localhost|example\.com)$'
###< symfony/framework-bundle ###

###> symfony/mailer ###
# MAILER_DSN=smtp://localhost
###< symfony/mailer ###

###> doctrine/doctrine-bundle ###
# Format described at https://www.doctrine-project.org/projects/doctrine-dbal/en/latest/reference/configuration.html#connecting-using-a-url
# For an SQLite database, use: "sqlite:///%kernel.project_dir%/var/data.db"
# For a PostgreSQL database, use: "postgresql://db_user:db_password@127.0.0.1:5432/db_name?serverVersion=11&charset=utf8"
# IMPORTANT: You MUST configure your server version, either here or in config/packages/doctrine.yaml
DATABASE_URL=mysql://sampleUserName:SamplePassword@127.0.0.1:3306/prod_cat?serverVersion=5.7
###< doctrine/doctrine-bundle ###

Вот мой doctrine .yaml

doctrine:
    dbal:
        url: '%env(resolve:DATABASE_URL)%'
        mapping_types:
            enum: string       
#        unix_socket: /Applications/MAMP/tmp/mysql/mysql.sock

        # IMPORTANT: You MUST configure your server version,
        # either here or in the DATABASE_URL env var (see .env file)
#        server_version: '5.7'
    orm:
        auto_generate_proxy_classes: true
        naming_strategy: doctrine.orm.naming_strategy.underscore_number_aware
        auto_mapping: true
        mappings:
            App:
                is_bundle: false
                type: annotation
                dir: '%kernel.project_dir%/src/Entity'
                prefix: 'App\Entity'
                alias: App

Чтобы упростить процесс ниже, я упоминаю соединительную строку из файла .env

 DATABASE_URL=mysql://sampleUserName:SamplePassword@127.0.0.1:3306/prod_cat?serverVersion=5.7

FYI:

  • Apache & MySQL включен и работает.

  • MySQL номер версии, который я упомянул, правильный

  • Имя пользователя и пароль верны.

1 Ответ

1 голос
/ 13 апреля 2020

Это может быть проблема, когда существует несоответствие в номере порта MySQL и в разделе Строка подключения .

Найти номер порта MySQL посетив страницу MySQL в PhpMyAdmin и используйте номер порта в строке подключения, либо используйте номер порта строки подключения в MySQL настройке порта.

Чтобы изменить MySQL Порт. Go Настройки на вкладке MAMP и Выбор портов, и вы можете обновить их там.

enter image description here

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