[解決済み] 不正な文字列値: '\xF0_x9F MySQL
Question
MYSQLのテーブルにツイートを保存しようとしています。 その ツイート は
<ブロッククオートquiero que me escuches, no te burles no te rias, anoche tuve un sueño que te fuiste de mi vida ?・・・・・・・・・・?
最後の二人の登場人物は、ともに
'複数の音符' (u+1f3b6)
であり、UTF-8 エンコーディングは
0xf09f8eb6
.
は
tweet_text
フィールドは、私のテーブルでは
utf8mb4
. しかし、そのカラムにツイートを格納しようとすると、次のようなエラーメッセージが表示されます。
Incorrect string value: '\xF0x9F' precedx8ExB6xF0x9F...' for column 'tweet_text' at row 1.
何が間違っているのでしょうか? どうすれば直せますか? 私は複数の言語も保存する必要があり、この文字セットはすべての言語で機能しますが、顔文字や絵文字などの特殊文字では機能しません。
これは私のテーブル作成ステートメントです。
CREATE TABLE `twitter_status_data` (
`unique_status_id` bigint(20) NOT NULL AUTO_INCREMENT,
`metadata_result_type` text CHARACTER SET utf8,
`created_at` text CHARACTER SET utf8 NOT NULL COMMENT 'UTC time when this Tweet was created.',
`id` bigint(20) unsigned NOT NULL COMMENT 'Unique tweet identifier',
`id_str` text CHARACTER SET utf8 NOT NULL,
`tweet_text` text COMMENT 'Actual UTF-8 text',
`user_id_str` text CHARACTER SET utf8,
`user_name` text COMMENT 'User''s name',
`user_screen_name` text COMMENT 'Twitter handle',
`coordinates` text CHARACTER SET utf8,
PRIMARY KEY (`unique_status_id`),
KEY `user_id_index` (`user_id`),
FULLTEXT KEY `tweet_text_index` (`tweet_text`)
) ENGINE=InnoDB AUTO_INCREMENT=82451 DEFAULT CHARSET=utf8mb4;
どのように解決するのですか?
私は最終的に問題を把握することができました。 私は、mysql の設定 my.ini のいくつかの設定を変更する必要がありました。 この記事はとても役に立ちました http://mathiasbynens.be/notes/mysql-utf8mb4#character-sets
まず、my.ini の文字セットを utf8mb4 に変更しました。 次に、mysqlクライアントで以下のコマンドを実行しました。
SET NAMES utf8mb4;
ALTER DATABASE dreams_twitter CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci;
次のコマンドを使用して、変更が行われたことを確認します。
SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';
関連
-
[解決済み] 親の行を削除または更新できない:外部キー制約が失敗する
-
SQL Server のトランザクションは、try キャッチに記述しなければ、中間ステートメントがエラーを報告してもコミットされます。
-
Unknown character set.を解決する。MySQLデータベースインポート時の'utf8mb4'エラーの解消
-
Mysqlの使用中に発生したエラーの一部
-
[解決済み] ユーザー 'root'@'localhost' (パスワード: YES を使用) のアクセス拒否 - 特権がない?
-
[解決済み] MySQLでdatetimeとtimestampのどちらのデータ型を使用すべきですか?
-
[解決済み] MySQLでコマンドラインを使用してSQLファイルをインポートするにはどうすればよいですか?
-
[解決済み] MySQLのAUTO_INCREMENTをリセットする方法
-
[解決済み] MySQL で特定のカラム名を持つすべてのテーブルを見つけるにはどうすればよいですか?
-
[解決済み】MySQLのDatetimeカラムにデフォルト値を設定する方法とは?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
MySQLにおけるorder byの使用方法の詳細
-
MySQLデータベースでvarchar型の数値の大きさを比較する方法
-
[解決済み】マルチパート識別子をバインドできませんでした。
-
[解決済み】ValueError: 値の長さがインデックスの長さと一致しない|Pandas DataFrame.unique()
-
SQLステートメントエラーです。オペランドには 1 つのカラムを含める必要があります [括弧を追加せずに複数のフィールドをクエリする
-
SQLException。オペランドは1列でなければなりません。
-
[解決済み] どのトランザクションが「テーブルメタデータのロック待ち」状態を引き起こしているかを確認するにはどうすればよいですか?
-
[解決済み] mysqladminのフラッシュホストでブロックを解除する方法
-
[解決済み] MySQLのクエリ結果をCSV形式で出力するにはどうすればよいですか?
-
[解決済み] MySQL で特定のカラム名を持つすべてのテーブルを見つけるにはどうすればよいですか?