视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
mysql远程机器导入导出数据锁表不锁表部分数据或全部
2020-11-09 09:09:55 责编:小采
文档


最近在使用mysql的时候,经常要遇到导出或者导入数据的情况,对于一些简单的,可以直接使用navicate直接导出结果,但是有很多时候,由于机器在远程端,并且是线上机器的情况下,在跳转一次跳转还链接不到mysql的时候,navicate就不能使用这种方法去导出了,搜索了网上的一些文章,大概将mysql导入导出的情况做个总结,如下:

一、导出数据库

mysqldump -h 127.0.0.1 -u name -p dbname >name.sql

将127.0.0.1的数据库dbname导出到name.sql文件里面

二、导出数据库的某张表

mysqldump -h 127.0.0.1 -u username -ppassword dbname tablename >name.sql

将ip 127.0.0.1上面的数据库dbname里面的tablename表导出到name.sql文件里面

三、导出数据库的某张表的符合某些条件的数据

mysqldump -h 127.0.0.1 -u username -ppassword dbname tablename --where="id>10 limit 10000" >name.sql

上面一、二的情况均属于将所有的表或者库全部导出来,但是有些时候我们只是想要部分的数据,这部分数据符合某些条件,对于上述的结构就是

将数据库dbname里面的tablename表里面的 id>10 的数据取出来100条,导出到name.sql文件里面

四、导出数据库的某张表不锁表

mysqldump -h 127.0.0.1 -u username -ppassword --single-transaction dbname tablename>name.sql

有时候导出的时候并没有锁表的权限,例如如果你只是一个只读权限的话,很可能没有锁表的权限,这个时候只要加上一句 --single-transaction 就可以不锁表进行导出

上述对于一、二、三来说都会对数据库进行锁表,加上此命令即可达到不锁表导数据的目的

五、导出数据库的某张表的表结构,不导出数据

mysqldump -h 127.0.0.1 -u username -ppassword --single-transaction -d dbname tablename>name.sql

有时候我们并不是要导出数据,只是要导出表结构,比如说你要按照这个表结构完全去复制创建这个表结构,这种情况下可以使用的方法很多,比如可以直接连上数据库,使用show create table tablename命令,也可以得到建表的语句;此处只是提供另外一种导出表结构的办法,如果要只导出表结构的话,可以加 -d就可以

六、导出数据库的某张表的数据,不导出结构

mysqldump -h 127.0.0.1 -u username -ppassword --single-transaction -t dbname tablename>name.sql

如果要只导出数据,但是不导出表结构的话,使用-t就可以达到目的,本来使用这一句的目的是为了导出数据库里面的视图,因为没有show create view的权限,只能尝试能否只导出数据,结果发现不太可以,再琢磨琢磨,再次mark一下,方便之后使用

七、数据库到导入

use dbname;
set names gbk;
source /d1/name/name.sql;

导入数据的时候只要连上数据库,使用source就可以,之前可以设置编码格式为gbk或者utf-8等,这样不会出现中文的乱码

八、授权

insert into mysql.user(User,Password) values("name",password("password"));

GRANT ALL PRIVILEGES ON *.* TO "name"@'%' IDENTIFIED BY 'password';

flush privileges;

show grants for 'test_group'@'%';

下载本文
显示全文
专题