Jest to kwestia sekwencji ucieczki i można to zrobić na kilka sposobów. Wybrałem po prostu umieszczenie początkowego pojedynczego cudzysłowu zagnieżdżonego wewnątrz zewnętrznych podwójnych cudzysłowów pod koniec pierwszego sposobu (z 3 kawałkami w concat
).
I pojedyncze cudzysłowy jako drugi sposób (z 2 kawałkami w concat
):
SET @filename = 'C:/icl/myfile.CSV';
-- C:/icl/myfile.CSV
SET @str = CONCAT('LOAD DATA INFILE ',@filename);
-- LOAD DATA INFILE C:/icl/myfile.CSV
-- First way is below (with the result being the line after it if you ignore the `-- ` at the beginning):
SET @str = CONCAT(@str," INTO TABLE icl_process_data.filecontent LINES TERMINATED BY '","\\n'");
-- LOAD DATA INFILE C:/icl/myfile.CSV INTO TABLE icl_process_data.filecontent LINES TERMINATED BY '\n'
-- Second way is below (with the result being the line after it if you ignore the `-- ` at the beginning):
SET @str = CONCAT('LOAD DATA INFILE ',@filename);
SET @str = CONCAT(@str,' INTO TABLE icl_process_data.filecontent LINES TERMINATED BY \'\\n\'');
-- LOAD DATA INFILE C:/icl/myfile.CSV INTO TABLE icl_process_data.filecontent LINES TERMINATED BY '\n'
Ze strony podręcznika mysql na Literały łańcuchowe :