Link to home
Start Free TrialLog in
Avatar of rleyba828
rleyba828Flag for Australia

asked on

Requesting assistance to export MySQL table to excel csv via the CLI

Hi Team,
   I am trying to do an export of one of my mysql tables to excel compatible csv and it works great from phpmyadmin but I want to script it via the command line.  Most of the table fields are text and may contain commas, and possibly even quotes and single quote,  etc. For some reason the phpmyadmin utility handles this well.  I just hope that the CLI will to it correctly as well.  One of the first stumbling blocks I am encountering now is that I need to include the doublequote character inside the single quote below, but I tried various variations, including escaping the double quote via  '\"' but the command still won't run properly.     That text below
Optionally enclosed by '"'

Open in new window

is what is giving me issues.  How can this be fixed?

mysql -u root -ppassword ChangeTemplate -e "SELECT * INTO OUTFILE 'Changes.xls'  FIELDS TERMINATED BY ','  LINES TERMINATED BY '\n' Optionally enclosed by '"' FROM ChangeTemplate.ChangeRecord;"

Open in new window


Thanks very much.
Avatar of ozo
ozo
Flag of United States of America image

mysql -u root -ppassword ChangeTemplate -e "SELECT * INTO OUTFILE 'Changes.xls'  FIELDS TERMINATED BY ','  LINES TERMINATED BY '\n' Optionally enclosed by '"'"'"' FROM ChangeTemplate.ChangeRecord;"
Avatar of rleyba828

ASKER

Hi Ozo,

  Thanks for your help above.   I literally did a copy and paste of your syntax and pasted it in...but I just got this error:

ERROR 1064 (42000) at line 1: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'Optionally enclosed by '"' FROM ChangeTemplate.ChangeRecord' at line 1

Open in new window


It seems to be really complaining about the Optionally enclosed by clause since if I remove this clause, then the command works fine.
I even tried this....but didn't work too:

mysql -u root -ppassword ChangeTemplate -e 'SELECT * INTO OUTFILE "Changes.xls"  FIELDS TERMINATED BY ","  LINES TERMINATED BY "\n" Optionally enclosed by """ FROM ChangeTemplate.ChangeRecord;'

Open in new window

ASKER CERTIFIED SOLUTION
Avatar of ozo
ozo
Flag of United States of America image

Link to home
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
Start Free Trial
Hi Ozo,
  You are right.  I rearranged the clauses so it now reads as below, and following your original suggestion, the new command below now works fine:

mysql -u root -ppassword ChangeTemplate -e "SELECT * INTO OUTFILE  'Changes.csv'  FIELDS TERMINATED BY  ','  ENCLOSED by   '"'"'"'  LINES TERMINATED BY  '\n'  FROM ChangeTemplate.ChangeRecord;"

Open in new window


Thanks very much for all your help.