MySQL INTO OUTFILE: Melarikan diri Aksara dalam CSV Exports
Untuk mengeksport data dengan cekap daripada pangkalan data MySQL ke fail CSV menggunakan arahan INTO OUTFILE , adalah penting untuk mengendalikan aksara khas seperti baris baharu dan koma dengan betul.
Pertimbangkan coretan kod yang disediakan:
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 ....
Isunya terletak pada penggunaan pilihan FIELDS ESCAPED BY '""', yang bertujuan untuk melepaskan semua aksara khas dalam keluaran. Walau bagaimanapun, pendekatan ini tidak sesuai dalam kes ini kerana ia boleh menyebabkan percanggahan dengan ", (koma), yang digunakan sebagai pembatas medan.
Untuk menyelesaikan isu ini, disyorkan untuk menggunakan PILIHAN DISERTAKAN OLEH pilihan '"' sebaliknya. Ini hanya akan melampirkan medan yang mengandungi aksara khas, manakala medan lain akan dieksport tanpa petikan.
Coretan kod yang diubah suai di bawah menggabungkan perubahan ini:
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
Selain itu, memanggil SET NAMES utf8; sebelum pemilihan fail luar boleh membantu memastikan pengekodan aksara adalah konsisten sepanjang proses eksport, menggunakan pengekodan UTF-8.
Dengan melaksanakan pelarasan ini, anda boleh mengeksport data dengan cekap daripada pangkalan data MySQL ke fail CSV sambil melarikan diri dengan betul aksara khas untuk mengekalkan integriti data dan mencegah isu semasa pengimportan dan analisis Excel.
Atas ialah kandungan terperinci Bagaimana untuk Melarikan Diri dengan Betul dalam Eksport CSV INTO OUTFILE MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!