1. 理由
1. 一貫性のない文字セット: Excel のデフォルトの文字セットは GB2312 ですが、MySQL のデフォルトの文字セットは UTF-8 または GBK です。送信中にデータが文字化けする可能性があります。
2. データ型の不一致: MySQL の VARCHAR および TEXT 型フィールドは異なる文字セットを格納できますが、Excel のセルは 1 つの文字セットのみをサポートします。 Excelのセルに異なる文字セットが含まれている場合、文字化けが発生する場合があります。
3. ファイル エンコーディングの不一致: Excel を使用して CSV 形式でファイルを開いたり保存したりすると、エンコーディングの不一致が発生する可能性があります。たとえば、CSV ファイルを保存するときに ANSI エンコードが選択されており、MySQL が UTF-8 エンコードを使用している場合、送信中にデータが文字化けする可能性があります。
2. 解決策
MySQL への接続時に一貫性のない文字セットによって引き起こされる文字化けを回避するには、文字セットを GB2312 に設定して文字を維持する必要があります。一貫して設定します。次のパラメータを MySQL Connector/ODBC に追加できます:
charset=GB2312
2. データ タイプのマッチング: MySQL データ テーブルを作成するとき、VARCHAR および TEXT タイプのフィールドを GB2312 として指定できます。キャラクターセット。例:
CREATE TABLE test (
id INT NOT NULL,
name VARCHAR(30) CHARACTER SET GB2312 DEFAULT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
ファイル エンコーディングの一貫性を維持するには、Excel を使用して CSV ファイルを保存するときに UTF-8 エンコーディングを選択する必要があります。たとえば、「ファイル」→「名前を付けて保存」をクリックし、「CSV UTF-8 (カンマ区切り)」形式を選択すると、Excel でファイルを保存できます。
さらに、場合によっては、SET NAMES コマンドを使用して MySQL の文字セットを設定することもできます。例:
SET NAMES 'GB2312'。
以上がExcelやMySQLを操作する際の文字化けを解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。