mysql 导出和导入

mysqldump -h$host -P$port -u$user --add-locks=0 --no-create-info --single-transaction  --set-gtid-purged=OFF db1 t --where="a>900" --result-file=/client_tmp/t.sql
这条命令中,主要参数含义如下:

–single-transaction的作用是,在导出数据的时候不需要对表db1.t加表锁,而是使用START TRANSACTION WITH CONSISTENT SNAPSHOT的方法;

–add-locks设置为0,表示在输出的文件结果里,不增加" LOCK TABLES t WRITE;" ;

–no-create-info的意思是,不需要导出表结构;

–set-gtid-purged=off表示的是,不输出跟GTID相关的信息;

–result-file指定了输出文件的路径,其中client表示生成的文件是在客户端机器上的。

–skip-extended-insert 一条INSERT语句只插入一行数据的话

mysql -h127.0.0.1 -P13000  -uroot db2 -e "source /client_tmp/t.sql"
show variables like 'secure_file_priv';
select * from db1.t where a>900 into outfile '/server_tmp/t.csv';
into outfile指定了文件的生成位置(/server_tmp/),这个位置必须受参数secure_file_priv的限制。参数secure_file_priv的可选值和作用分别是:

如果设置为empty,表示不限制文件生成的位置,这是不安全的设置;
如果设置为一个表示路径的字符串,就要求生成的文件只能放在这个指定的目录,或者它的子目录;
如果设置为NULL,就表示禁止在这个MySQL实例上执行select … into outfile 操作。

load data infile '/server_tmp/t.csv' into table db2.t;

你可能感兴趣的:(mysql 导出和导入)