是否可以通过单个SQL查询来做mysqldump ?

我的意思是转储整个数据库,就像phpmyadmin在导出到SQL时所做的那样


当前回答

您可以像这样将查询转储为csv:

SELECT * from myTable
INTO OUTFILE '/tmp/querydump.csv'
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n'

其他回答

MySQL Workbench在GUI中也有这个功能。简单地运行一个查询,点击导出/导入旁边的保存图标:

在列表中选择“SQL INSERT语句(*. SQL)”。

输入一个名称,单击保存,确认表名,您将有您的转储文件。

不是mysqldump,而是mysql cli…

mysql -e "select * from myTable" -u myuser -pxxxxxxxxx mydatabase

你可以重定向到一个文件,如果你想:

mysql -e "select * from myTable" -u myuser -pxxxxxxxx mydatabase > mydumpfile.txt

更新: 最初的帖子问他是否可以通过查询从数据库转储。他问的和他的意思是不一样的。他只想mysqldump所有表。

mysqldump --tables myTable --where="id < 1000"

如果您想将最近n条记录导出到一个文件中,您可以运行以下命令:

mysqldump -u user -p -h localhost --where "1=1 ORDER BY id DESC LIMIT 100" database table > export_file.sql

上面将最后100条记录保存到export_file中。Sql,假设要导出的表有一个自动递增的id列。

您需要修改用户、本地主机、数据库和表的值。您可以选择更改id列和导出文件名。

要转储特定的表,

mysqldump -u root -p dbname -t tablename --where="id<30" > post.sql

使用where查询转储表:

mysqldump mydatabase mytable --where="mycolumn = myvalue" --no-create-info > data.sql

转储整个表:

mysqldump mydatabase mytable > data.sql

注:

用你想要的值替换mydatabase、mytable和where语句。 默认情况下,mysqldump将在输出中包含DROP TABLE和CREATE TABLE语句。因此,如果您希望在从保存的数据文件恢复时不删除表中的所有数据,请确保使用——no-create-info选项。 您可能需要在上面的示例命令中添加适当的-h、-u和-p选项,以便分别指定所需的数据库主机、用户和密码。