MOON
Server: Apache
System: Linux res.emeff.ca 3.10.0-962.3.2.lve1.5.24.10.el7.x86_64 #1 SMP Wed Mar 20 07:36:02 EDT 2019 x86_64
User: accemeff (1004)
PHP: 7.0.33
Disabled: NONE
Upload Files
File: /home/accemeff/vendor/craftcms/cms/docs/ja/config/db-settings.md
# データベース接続設定

Craft は、Craft がどのようにデータベースへ接続するかを制御するためのいくつかのデータベース接続設定をサポートしています。

最終的に、データベース接続設定は `config/db.php` からセットしなければなりません。しかし、最初に(`.env` ファイルのような)環境変数としてセットしてから、`config/db.php` 内で [getenv()](http://php.net/manual/en/function.getenv.php) を使用して環境変数の値を取得することを推奨します。

例えば、新しい Craft 3 プロジェクト内の `.env` ファイルでは、次の環境変数を定義する必要があります。

```bash
ENVIRONMENT="dev"
SECURITY_KEY=""
DB_DRIVER="mysql"
DB_SERVER="localhost"
DB_USER="root"
DB_PASSWORD=""
DB_DATABASE=""
DB_SCHEMA="public"
DB_TABLE_PREFIX=""
DB_PORT=""
```

`DB_` ではじまる変数はデータベース接続設定で、`config/db.php` の中から次のように取得します。

```php
return [
    'driver' => getenv('DB_DRIVER'),
    'server' => getenv('DB_SERVER'),
    'user' => getenv('DB_USER'),
    'password' => getenv('DB_PASSWORD'),
    'database' => getenv('DB_DATABASE'),
    'schema' => getenv('DB_SCHEMA'),
    'tablePrefix' => getenv('DB_TABLE_PREFIX'),
    'port' => getenv('DB_PORT')
];
```

私たちがこのような環境変数のアプローチを推奨するには、2つの理由があります。

1. 機密情報をプロジェクトのコードベースから守ります。(`.env` ファイルは、共有したり Git にコミットするべきではありません。)
2. それぞれの開発者が他者の設定を上書きすることなく独自の設定を定義できるため、他の開発者とのコラボレーションを容易にします。

Craft がサポートするデータベース接続設定の完全なリストは、次の通りです。

<!-- BEGIN SETTINGS -->

### `attributes`

許可される型

:   [array](http://php.net/language.types.array)

デフォルト値

:   `[]`

定義元

:   [DbConfig::$attributes](api:craft\config\DbConfig::$attributes)

PDO コンストラクタに渡す PDO 属性の key => value ペアの配列。

例えば、MySQL PDO ドライバ(http://php.net/manual/en/ref.pdo-mysql.php)を使用する場合、(MySQL で SSL が利用できると仮定する https://dev.mysql.com/doc/refman/5.5/en/using-secure-connections.html)SSL データベース接続で `'user'` が SSL 経由で接続できる場合、次のように設定します。

```php
[
    PDO::MYSQL_ATTR_SSL_KEY    => '/path/to/my/client-key.pem',
    PDO::MYSQL_ATTR_SSL_CERT   => '/path/to/my/client-cert.pem',
    PDO::MYSQL_ATTR_SSL_CA     => '/path/to/my/ca-cert.pem',
],
```

### `charset`

許可される型

:   [string](http://php.net/language.types.string)

デフォルト値

:   `'utf8'`

定義元

:   [DbConfig::$charset](api:craft\config\DbConfig::$charset)

テーブルを作成する際に使用する文字セット。

### `database`

許可される型

:   [string](http://php.net/language.types.string)

デフォルト値

:   `''`

定義元

:   [DbConfig::$database](api:craft\config\DbConfig::$database)

選択するデータベースの名前。

### `driver`

許可される型

:   [string](http://php.net/language.types.string)

デフォルト値

:   `self::DRIVER_MYSQL`

定義元

:   [DbConfig::$driver](api:craft\config\DbConfig::$driver)

使用するデータベースのドライバ。MySQL 向けの 'mysql'、または、PostgreSQL 向けの 'pgsql'。

### `dsn`

許可される型

:   [string](http://php.net/language.types.string)

デフォルト値

:   `null`

定義元

:   [DbConfig::$dsn](api:craft\config\DbConfig::$dsn)

手動で PDO DSN 接続文字列を指定する場合は、ここで設定できます。

- MySQL: http://php.net/manual/en/ref.pdo-mysql.connection.php
- PostgreSQL: http://php.net/manual/en/ref.pdo-pgsql.connection.php
これを設定すると、[$server](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-server)、[$port](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-port)、[$user](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-user)、[$password](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-password)、[$database](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-database)、
[$driver](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-driver) および [$unixSocket](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-unixsocket) コンフィグ設定は無視されます。

### `password`

許可される型

:   [string](http://php.net/language.types.string)

デフォルト値

:   `''`

定義元

:   [DbConfig::$password](api:craft\config\DbConfig::$password)

接続するデータベースのパスワード。

### `port`

許可される型

:   [integer](http://php.net/language.types.integer)

デフォルト値

:   `null`

定義元

:   [DbConfig::$port](api:craft\config\DbConfig::$port)

データベースサーバーのポート。デフォルトは、MySQL 向けの 3306、および、PostgreSQL 向けの 5432。

### `schema`

許可される型

:   [string](http://php.net/language.types.string)

デフォルト値

:   `'public'`

定義元

:   [DbConfig::$schema](api:craft\config\DbConfig::$schema)

使用するデータベースのスキーマ(PostgreSQL のみ)。

### `server`

許可される型

:   [string](http://php.net/language.types.string)

デフォルト値

:   `'localhost'`

定義元

:   [DbConfig::$server](api:craft\config\DbConfig::$server)

データベースのサーバー名、または、IP アドレス。通常は 'localhost' または '127.0.0.1' です。

### `tablePrefix`

許可される型

:   [string](http://php.net/language.types.string)

デフォルト値

:   `''`

定義元

:   [DbConfig::$tablePrefix](api:craft\config\DbConfig::$tablePrefix)

共有するCraft のインストールを単一のデータベース(MySQL)、または、単一のデータベースで共有スキーマ(PostgreSQL)を使用する場合、インストールごとにテーブル名の競合を避けるために、テーブル接頭辞をセットできます。これは5文字以内、かつ、すべて小文字でなければなりません。

### `unixSocket`

許可される型

:   [string](http://php.net/language.types.string), [null](http://php.net/language.types.null)

デフォルト値

:   `null`

定義元

:   [DbConfig::$unixSocket](api:craft\config\DbConfig::$unixSocket)

MySQL のみ。セットされている場合、(yiic で使用される)CLI 接続文字列は、 サーバーやポートの代わりに Unix ソケットに接続します。これを指定すると、'server' と 'port' 設定が無視されます。

### `url`

許可される型

:   [string](http://php.net/language.types.string), [null](http://php.net/language.types.null)

デフォルト値

:   `null`

定義元

:   [DbConfig::$url](api:craft\config\DbConfig::$url)

ホスティング環境によって提供された場合、データベースの接続 URL。

セットされている場合、[$driver](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-driver)、[$user](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-user)、[$database](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-database)、[$server](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-server)、[$port](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-port)、および、 [$database](https://docs.craftcms.com/api/v3/craft-config-dbconfig.html#property-database) の値は、そこから抽出されます。

### `user`

許可される型

:   [string](http://php.net/language.types.string)

デフォルト値

:   `'root'`

定義元

:   [DbConfig::$user](api:craft\config\DbConfig::$user)

接続するデータベースのユーザー名。

<!-- END SETTINGS -->