MySQL查询转储

是否可以通过单个SQL query来实现mysqldump ?

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

398552 次浏览

不是mysqldump,而是mysql cli…

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

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

mysql -e "select * from myTable" -u myuser -pxxxxxxxx mydatabase > mydumpfile.txt
< p >更新: 最初的帖子问他是否可以通过查询从数据库转储。他问的和他的意思是不一样的。他真的想mysqldump所有的表
mysqldump --tables myTable --where="id < 1000"

这应该可以

mysqldump --databases X --tables Y --where="1 limit 1000000"

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

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

你可以使用mysqldump上的——where选项来生成你正在等待的输出:

mysqldump -u root -p test t1 --where="1=1 limit 100" > arquivo.sql

来自测试的最多100行。T1将从数据库表中转储。

使用where查询转储表:

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

转储整个表:

mysqldump mydatabase mytable > data.sql

注:

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

结合以上的许多内容,这里是我的实际示例,基于计量和amp选择记录;时间戳。多年来我一直需要这个命令。执行得非常快。

mysqldump -uuser -ppassword main_dbo trHourly --where="MeterID =5406 AND TIMESTAMP<'2014-10-13 05:00:00'" --no-create-info --skip-extended-insert | grep  '^INSERT' > 5406.sql

导出查询结果命令行:

mysql -h120.26.133.63 -umiyadb -proot123 miya -e "select * from user where id=1" > mydumpfile.txt

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

enter image description here

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

enter image description here

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

如果您想将最近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列和导出文件名。

如果您想从表中转储特定的字段,这可能很方便

1/创建临时表与你的查询。

create table tmptable select field1, field2, field3 from mytable where filter1 and fileter2 ;

2/ dump整个临时表。然后就有了包含特定字段的转储文件。

mysqldump -u user -p mydatabase tmptable > my-quick-dump.sql

要转储特定的表,

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

下面是我的mysqldump从不同的表中选择相同的关系:

 mysqldump --defaults-file=~/.mysql/datenbank.rc -Q -t -c --hex-blob \
--default-character-set=utf8 --where="`cat where-relation-ids-in.sql`" \
datenbank table01 table02 table03 table04 > recovered-data.sql

where-relation-ids-in.sql:

relation_id IN (6384291, 6384068, 6383414)

~ / .mysql / datenbank.rc

[client]
user=db_user
password=db_password
host=127.0.0.1

注意:如果你的relation_id文件很大,where子句的注释将在转储文件中被删除,但所有数据都是正确选择的;-)

我希望它能帮助到一些人;-)