是否可以通过单个SQL查询来做mysqldump ?
我的意思是转储整个数据库,就像phpmyadmin在导出到SQL时所做的那样
是否可以通过单个SQL查询来做mysqldump ?
我的意思是转储整个数据库,就像phpmyadmin在导出到SQL时所做的那样
当前回答
你可以使用mysqldump上的——where选项来生成你正在等待的输出:
mysqldump -u root -p test t1 --where="1=1 limit 100" > arquivo.sql
来自测试的最多100行。T1将从数据库表中转储。
其他回答
您可以像这样将查询转储为csv:
SELECT * from myTable
INTO OUTFILE '/tmp/querydump.csv'
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n'
如果您想从表中转储特定的字段,这可能很方便
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从不同的表中选择相同的关系:
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子句的注释将在转储文件中被删除,但所有数据都是正确选择的;-)
我希望它能帮助到一些人;-)
MySQL Workbench在GUI中也有这个功能。简单地运行一个查询,点击导出/导入旁边的保存图标:
在列表中选择“SQL INSERT语句(*. SQL)”。
输入一个名称,单击保存,确认表名,您将有您的转储文件。
你可以使用mysqldump上的——where选项来生成你正在等待的输出:
mysqldump -u root -p test t1 --where="1=1 limit 100" > arquivo.sql
来自测试的最多100行。T1将从数据库表中转储。