MySQL INTO OUTFILE: CSV エクスポートでの文字のエスケープ
INTO OUTFILE コマンドを使用して MySQL データベースから CSV ファイルにデータを効率的にエクスポートするには、改行やカンマなどの特殊文字を処理することが重要です
提供されているコード スニペットを検討してください:
SELECT id, client, project, task, REPLACE(REPLACE(ifnull(ts.description,''),'\n',' '),'\r',' ') AS description, time, date INTO OUTFILE '/path/to/file.csv' FIELDS ESCAPED BY '""' TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n' FROM ....
問題は、FIELDS ESCAPED BY '""' オプションの使用にあります。これは、フィールド内のすべての特殊文字をエスケープすることを目的としています。出力。ただし、このアプローチは、フィールド区切り文字として使用される ", (カンマ) と競合する可能性があるため、この場合には適していません。
この問題を解決するには、OPTIONALLY ENCLOSED を使用することをお勧めします。代わりに BY '"' オプションを使用してください。これにより、特殊文字を含むフィールドのみが囲まれ、他のフィールドは引用符なしでエクスポートされます。
以下の変更されたコード スニペットには、この変更が組み込まれています。
SELECT id, client, project, task, description, time, date INTO OUTFILE '/path/to/file.csv' FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY '\n' FROM ts
さらに、SET NAMES utf8; を呼び出します。 outfile select の前に、UTF-8 エンコーディングを使用して、エクスポート プロセス全体で文字エンコーディングの一貫性を確保するのに役立ちます。
これらの調整を実装することで、適切にエスケープしながら、MySQL データベースから CSV ファイルにデータを効率的にエクスポートできます。特殊文字を使用してデータの整合性を維持し、Excel のインポートおよび分析中に問題が発生するのを防ぎます。
以上がMySQL の INTO OUTFILE CSV エクスポートで文字を適切にエスケープする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。