linux下mysqldump导出数据、表结构,导入数据
导出完整的数据库备份
- mysqldump -h127.0.0.1 -P3306 -uroot -ppassword --add-locks -q dbname > dbname.sql
说明:前面这些地址、端口就不说明了,都知道。说下后面的,--add-locks:导出过程中锁定表,完成后回解锁。-q:不缓冲查询,直接导出至标准输出
如:
- LOCK TABLES `user` WRITE;
- DROP TABLE IF EXISTS `user`;
- CREATE TABLE `user` (
- `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
- `name` varchar(50) NOT NULL DEFAULT '',
- ) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
- INSERT INTO `user` VALUES ('1', 'name1');
- INSERT INTO `user` VALUES ('2', 'name2');
- UNLOCK TABLES;
导出完整的数据库表结构
- mysqldump -h127.0.0.1 -P3306 -uroot -ppassword --add-locks -q -d dbname > dbname.sql
说明:-d:只导出表结构,不含数据
如:
- LOCK TABLES `user` WRITE;
- CREATE TABLE `user` (
- `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
- `name` varchar(50) NOT NULL DEFAULT '',
- ) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
- UNLOCK TABLES;
导出完整的数据库的数据不含表结构
- mysqldump -h127.0.0.1 -P3306 -uroot -ppassword --add-locks -q -t dbname.user > dbname.sql
如:
- LOCK TABLES `user` WRITE;
- INSERT INTO `user` VALUES ('1', 'name1');
- INSERT INTO `user` VALUES ('2', 'name2');
- UNLOCK TABLES;
问题:
也许有人已经发现了,auto_increment的问题,导出的是表中的值,如果表本身数据很多,
其值就会很大,如果我要表结构的话,基数就会很大,总感觉不爽。谁有办法请留言。谢啦!!
导入数据:mysqlimport -u用户名 -p密码 数据库DB 路径(最后的文件名如果是ssdd.txt,则对应导入的表名即为数据库DB下的ssdd)
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步