MySQL で珍しい文字を挿入できないときの対処方法 (文字列値が正しくない)

MySQL で珍しい文字を挿入できないときの対処方法 (文字列値が正しくない)

最近、ビジネス側から、一部のユーザー情報の挿入に失敗し、エラー メッセージが「不正な文字列値:"\xF0\xA5....."」に似ているという報告がありました。このメッセージから判断すると、文字セットが特定の珍しい文字をサポートしていないことが原因であると思われます。

仮想マシンで再現されたシナリオは次のとおりです。

ステップ 1: 元のテーブル構造の文字セット環境をシミュレートします。

使用テスト;
テーブル `t1` を作成します (
 `id` int(10) NOT NULL AUTO_INCREMENT,
 `real_name` varchar(255) 文字セット utf8 デフォルト '' コメント '名前',
 `nick` varchar(100) COLLATE utf8mb4_unicode_ci DEFAULT '' COMMENT 'ニックネーム',
 主キー (`id`)
) ENGINE=InnoDBAUTO_INCREMENT=10 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='会員カード';

ステップ 2、まれな単語を挿入します (sqlyog シミュレーションを使用)。

1. まずオンライン環境をシミュレートし、文字セットを設定します。

wKiom1kUGECCXdKDAAAV9L1hpEY173.png

2. 珍しい文字を挿入します(珍しい文字については、http://www.qqxiuzi.cn/zh/hanzi-unicode-bianma.php?zfj=kzb&ks=24E20&js=257E3 を参照してください)。

wKioL1kUGEHCtaAvAABxJXp_7Ow741.png

Wang を挿入してみます (Word で ALT キーを押しながら 152964 と入力します)。挿入が失敗したことがわかります。

ステップ3. real_nameの文字セットを変更します。

使用テスト;

alter table t1 change real_name real_name varchar(255) CHARACTER SET utf8mb4 DEFAULT '' COMMENT 'Name';

大きなオンライン テーブルの場合は、pt-osc を使用して処理できます。コマンドは次のとおりです。

pt-online-schema-change -uroot -h localhost --alter=" real_name を変更 real_name varchar(255) 文字セット utf8mb4 デフォルト '' コメント '姓名' " D=test, t=t1 --no-check-replication-filters --alter-foreign-keys-method=auto --recursion-method=none --quiet --charset=utf8mb4 --dry-run
pt-online-schema-change -uroot -h localhost --alter=" real_name を変更 real_name varchar(255) 文字セット utf8mb4 デフォルト '' コメント '姓名' " D=test, t=t1 --no-check-replication-filters --alter-foreign-keys-method=auto --recursion-method=none --quiet --charset=utf8mb4 --execute

ステップ 4: 実験を再度挿入します。

1. まず文字セットを設定します。

wKiom1kUGECCXdKDAAAV9L1hpEY173.png

2. 再度挿入すると、挿入が成功したことを確認できます。

wKioL1kUGILTLvpxAAAdWKxKR5A899.png

コマンドラインクエリには文字化けしたコードはありません。

wKiom1kUGIPyeykFAAAiRzDqNxs956.png

以上です、参考にしてください。

以下もご興味があるかもしれません:
  • MySQL に絵文字を保存するときに表示されるエラー メッセージ「java.sql.SQLException: 文字列値が正しくありません:'\xF0\x9F\x92\xA9\x0D\x0A...'」の解決方法
  • MySQL が不正な文字列値の例外分析をスローする
  • MySql エラー 列の文字列値が正しくありません
  • MySQL の不正な文字列値の解決方法

<<:  Nodejs でタイムドクローラーを実装する完全な例

>>:  win2008 サーバー セキュリティ設定の展開ドキュメント (推奨)

推薦する

HTML 特殊文字変換表

キャラクター小数点文字番号エンティティ名---未使用空間---スペースバー! ! ---感嘆符「 」...

MySQL パーティションテーブルの正しい使用方法

MySQL パーティションテーブルの概要数億、あるいは数十億ものレコードを格納するテーブルに遭遇する...

新しい CSS display:box プロパティの詳細な説明

1. ディスプレイボックス;要素にこのプロパティを設定すると、display:inline-bloc...

HTMLウェブページのMETAタグのコンテンツを書く際のポイント

META タグは、HTML 言語のヘッダー領域にある補助タグです。作成者、日時、Web ページの説明...

axios でリクエストをキャンセルし、重複リクエストを防ぐ方法について簡単に説明します。

目次序文コア - キャンセルトークン実用的なアプリケーションとパッケージングいくつかの小さな詳細序文...

Linux で MySQL データベースのインポートおよびエクスポート コマンドを実装する方法

1. mysqldump コマンドを使用してデータベースをエクスポートします (このコマンドのパスで...

JS でオブジェクトが空オブジェクトかどうかを判断する 5 つの方法

1. jsonオブジェクトをjson文字列に変換し、文字列が「{}」であるかどうかを判断します。 v...

画像の盗難を防ぐために Nginx で Referer を設定する方法

サーバーの画像が他のウェブサイトからホットリンクされると、サーバーの帯域幅とアクセス速度に影響します...

Javascriptのクロージャとアプリケーションの詳細な説明

目次序文1. クロージャとは何ですか? 1.1 クロージャは条件コードを満たす1.2 クロージャ生成...

Win10 への MySQL 5.7 のインストール MSI 版のチュートリアル(画像とテキスト付き)

主にインストール後に my.ini ファイルを確認するために、msi 形式でインストールしました。フ...

Reactの原理の説明

目次1. setState() の説明1.1 データの更新1.2 推奨構文1.3 2番目のパラメータ...

Dockerコンテナレイヤーの概念の詳細な説明

目次01 コンテナの一貫性02 レイヤーの概念03 レイヤードデザインの利点今日はコンテナ レイヤー...

MySQL (5.6 以下) の JSON 解析の詳細な例

MySQL(5.6以下)はjsonを解析します #json 解析関数 DELIMITER $$ `j...

Vue検証コードコンポーネントの使い方の詳しい説明

この記事の例では、vue検証コードコンポーネントで使用される具体的な実装コードを参考までに共有してい...

最もよく使われるHTMLエスケープシーケンス

HTML では、<、>、& などは特別な意味を持ち (<、> はリン...