「MySQL - データベース」の版間の差分
(→照合順序とは) |
(→概要) |
||
1行目: | 1行目: | ||
== 概要 == | == 概要 == | ||
<br><br> | |||
== データベースの作成 == | |||
==== 文字コード ==== | |||
データベースの作成時において、文字コードを指定する。<br> | |||
<syntaxhighlight lang="mysql"> | |||
CREATE DATABASE <データベース名> | |||
CHARACTER SET=utf8mb4 -- 文字コードをutf8mb4に指定する場合 | |||
</syntaxhighlight> | |||
<br> | |||
MySQLのデフォルトの文字コードを確認する。<br> | |||
<syntaxhighlight lang="mysql"> | |||
Show Variables Like "chara%"; | |||
</syntaxhighlight> | |||
<br> | |||
MySQLのデフォルトの文字コードを設定する場合は、my.cnfファイルを編集する。<br> | |||
<syntaxhighlight lang="ini"> | |||
# my.cnfファイル | |||
[mysqld] | |||
character-set-server=utf8mb4 # MySQLサーバのデフォルトの文字コードを指定する | |||
[client] | |||
default-character-set=utf8mb4 # MySQLクライアントのデフォルトの文字コードを指定する | |||
</syntaxhighlight> | |||
<br> | |||
既存のデータベースの文字コードは、INFORMATION_SCHEMAデータベースのSCHEMATAテーブルから確認することができる。<br> | |||
<syntaxhighlight lang="mysql"> | |||
SELECT SCHEMA_NAME,DEFAULT_CHARACTER_SET_NAME | |||
FROM INFORMATION_SCHEMA.SCHEMATA | |||
WHERE SCHEMA_NAME = '<データベース名>'; | |||
</syntaxhighlight> | |||
<br> | |||
既存のデータベースの文字コードを変更する。<br> | |||
<syntaxhighlight lang="mysql"> | |||
ALTER DATABASE <データベース名> | |||
[[DEFAULT] CHARACTER SET <文字コード>] | |||
[[DEFAULT] COLLATE <照合順序>] | |||
# 例: 文字コードはutf8mb4, 照合順序はutf8mb4_general_ci | |||
ALTER DATABASE <データベース名> | |||
CHARACTER SET utf8mb4 | |||
COLLATE utf8mb4_general_ci; | |||
</syntaxhighlight> | |||
<br> | |||
==== 既存のデータベースの存在を確認して作成 ==== | |||
既存のデータベースが存在していない場合はデータベースを作成する。<br> | |||
これは、データベースの重複、または、既存のデータベースを上書き/削除することを防ぐことができる。<br> | |||
CREATE DATABASE IF NOT EXISTS <データベース名> | |||
CHARACTER SET=utf8mb4 | |||
<br> | |||
==== データベースの暗号化 ==== | |||
暗号化プラグインのインストールが必要である。<br> | |||
CREATE DATABASE IF NOT EXISTS <データベース名> | |||
CHARACTER SET=utf8mb4 | |||
ENCRYPTION='Y' -- 暗号化を有効にする場合 | |||
-- 無効にする場合は、Nを指定する | |||
<br><br> | <br><br> | ||
2024年1月13日 (土) 18:48時点における版
概要
データベースの作成
文字コード
データベースの作成時において、文字コードを指定する。
CREATE DATABASE <データベース名>
CHARACTER SET=utf8mb4 -- 文字コードをutf8mb4に指定する場合
MySQLのデフォルトの文字コードを確認する。
Show Variables Like "chara%";
MySQLのデフォルトの文字コードを設定する場合は、my.cnfファイルを編集する。
# my.cnfファイル
[mysqld]
character-set-server=utf8mb4 # MySQLサーバのデフォルトの文字コードを指定する
[client]
default-character-set=utf8mb4 # MySQLクライアントのデフォルトの文字コードを指定する
既存のデータベースの文字コードは、INFORMATION_SCHEMAデータベースのSCHEMATAテーブルから確認することができる。
SELECT SCHEMA_NAME,DEFAULT_CHARACTER_SET_NAME
FROM INFORMATION_SCHEMA.SCHEMATA
WHERE SCHEMA_NAME = '<データベース名>';
既存のデータベースの文字コードを変更する。
ALTER DATABASE <データベース名>
[[DEFAULT] CHARACTER SET <文字コード>]
[[DEFAULT] COLLATE <照合順序>]
# 例: 文字コードはutf8mb4, 照合順序はutf8mb4_general_ci
ALTER DATABASE <データベース名>
CHARACTER SET utf8mb4
COLLATE utf8mb4_general_ci;
既存のデータベースの存在を確認して作成
既存のデータベースが存在していない場合はデータベースを作成する。
これは、データベースの重複、または、既存のデータベースを上書き/削除することを防ぐことができる。
CREATE DATABASE IF NOT EXISTS <データベース名> CHARACTER SET=utf8mb4
データベースの暗号化
暗号化プラグインのインストールが必要である。
CREATE DATABASE IF NOT EXISTS <データベース名> CHARACTER SET=utf8mb4 ENCRYPTION='Y' -- 暗号化を有効にする場合 -- 無効にする場合は、Nを指定する
照合順序
照合順序とは
MySQLにおいて、照合順序(Collation)はテーブルや列ごとに設定することができる。
照合順序は、文字列の比較やソートの際に使用され、異なる言語や地域に合わせてテキストの比較を行うために重要である。
MySQLでは、様々な照合順序が提供されている。
例えば、大文字小文字を区別やアクセントを考慮するかどうか等の違いがある。
- utf8mb4_general_ci
- 大文字小文字を区別せず、アクセントを区別しない。
- 通常の比較の場合には適しているが、文字の並び順は一般的な場合に従う。
- utf8mb4_bin
- バイナリ比較を行う。
- 大文字小文字やアクセント等を区別して、バイト単位で比較する。
- これは厳密なバイナリ比較が必要な場合に使用される。
- utf8_general_ci
- utf8mb4と同様、大文字小文字を区別せず、アクセントを区別しない。
- ただし、utf8mb4よりも少ない文字セットを使用する。
- latin1_swedish_ci
- ラテン1文字セットに基づいた照合順序であり、スウェーデンの標準に従う。
- 大文字小文字を区別せず、アクセントを区別しない。
照合順序の詳細を知りたい場合は、MySQLの公式ドキュメントを参照すること。
データベース作成時における照合順序の指定
以下の例では、データベースの作成時において、照合順序をutf8mb4_unicode_ciに指定している。
CREATE DATABASE <データベース名> {
CHARACTER SET utf8mb4
COLLATE utf8mb4_unicode_ci;
};
※注意
照合順序は、データベース、テーブル、列ごとに指定することができ、異なる部分で異なる照合順序が設定されることがある。
デフォルトの照合順序
データベースやテーブルの照合順序が指定されていない場合、デフォルトの照合順序が使用される。
一般的に、MySQLのデフォルトの照合順序は、サーバの文字セットに基づいている。
例えば、MySQLデータベースを作成時に指定された文字セットに応じて、デフォルトの照合順序が選択される。
一般的なデフォルトの文字セットと照合順序の組み合わせには、以下に示すようなものがある。
ほとんどの場合、UTF-8マルチバイト文字セットとその一般的な照合順序がデフォルトとして使用される。
- utf8mb4
- utf8mb4_general_ci
デフォルトの照合順序を確認する場合は、以下に示すクエリを実行する。
SHOW VARIABLES LIKE 'collation%';
このクエリは、サーバの照合順序に関する情報を表示する。
デフォルトの照合順序は、collation_server
として表示される。