質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

Q&A

解決済

3回答

1925閲覧

MySQL で utf-8 のデータベースを utf-8mb4 に変換する際のリスク

hos

総合スコア33

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

0グッド

3クリップ

投稿2022/02/21 06:15

知りたいこと

  • MySQL の utf-8 なテーブルを utf8mb4 に変換する際のリスク。
  • 一部のカラムのみを変換したほうが良いか。全テーブルを変換したほうが良いか。
  • 実際変換を行った場合に出た問題点

説明

現在 MySQLで utf-8 のテーブルを運用しています。
こちらを utf-8mb4 に変換しようとしています。

変換する際のリスクや問題点、考慮すべきものはどのようなものが考えられるでしょうか?
カラム長やインデックス長については情報があるのですが、
変換にかかる時間や想定外のトラブルなど経験された方がいらしゃったら情報を知りたいです。

付記

インデックスや結合に関する問題は下記を参照しています。
https://dev.mysql.com/doc/refman/5.6/ja/charset-unicode-upgrading.html

テーブルのカラムを変更する場合は下記のようなSQLを考えています。

SQL

1ALTER TABLE hoge.fuga 2CONVERT TO CHARACTER SET utf8mb4 3COLLATE utf8mb4_general_ci;

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

ベストアンサー

一部のカラムのみを変換したほうが良いか。全テーブルを変換したほうが良いか。

これは「全部一斉に変換する」のほぼ一択と考えます。

utf8mb4の列とutf8の列を混在させるような演算を行う場合には、照合順序を逐一指定しないとエラーになってしまうOracle)ので、混在すると実用上の不便が大きいです。

投稿2022/02/21 06:22

maisumakun

総合スコア145184

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

上位互換のcollateに変換するリスクは、後戻りができないことです。
一部でも利用するなら全部適用しても変わりないと思います。
ただしテーブルのcollateを変更してもあまり意味はなくカラムごとに設定が必要だと思います

投稿2022/02/21 06:20

yambejp

総合スコア114843

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

お二人ともありがとうございます!

やはり全テーブルを変換する方向で進めたいと思います。

投稿2022/02/21 09:07

hos

総合スコア33

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問