【mysql】导出导入mysql表结构或者数据

使用 mysqldump 工具可以方便地导出 MySQL 数据库中的表数据。mysqldump 是一个命令行工具,通常随 MySQL 服务器一起安装。以下是如何使用 mysqldump 导出表数据的步骤和示例。

基本语法
复制代码
mysqldump -h[ip地址] -P[端口] -u [用户名] -p [数据库名] [表名] > [输出文件名].sql
示例

假设您有一个名为 mydatabase 的数据库,其中有一个名为 user_manage 的表,您想将该表的数据导出到一个名为 user_manage_backup.sql 的文件中。

  1. 打开命令行终端(在 Windows 上是命令提示符或 PowerShell,在 macOS 或 Linux 上是终端)。

  2. 运行 mysqldump 命令

    mysqldump -u your_username -p mydatabase user_manage > user_manage_backup.sql

  • -u your_username:指定您的 MySQL 用户名。
  • -p:提示输入密码。
  • mydatabase:要导出数据的数据库名称。
  • user_manage:要导出数据的表名称。
  • > user_manage_backup.sql:将导出的数据保存到 user_manage_backup.sql 文件中。
其他常用选项
导出数据包含中文

在windows cmd窗口,加参数--default-character-set UTF8

复制代码
mysqldump -h 192.168.10.10 -P3306 -uroot -proot --default-character-set UTF8 --databases  mydatabase > mydatabase_backup.sql
只导出数据(不包含表结构)

如果您只想导出表中的数据而不包含表结构,可以使用 --no-create-info 选项:

复制代码
mysqldump -u your_username -p --no-create-info mydatabase user_manage > user_manage_data_only.sql
只导出表结构(不包含数据)

如果您只想导出表结构而不包含数据,可以使用 --no-data 选项:

复制代码
mysqldump -u your_username -p --no-data mydatabase user_manage > user_manage_structure_only.sql
添加锁以确保一致性

对于大型数据库,您可以使用 --single-transaction--quick 选项来避免长时间锁定表,并确保事务的一致性:

复制代码
mysqldump -u your_username -p --single-transaction --quick mydatabase user_manage > user_manage_backup.sql
压缩导出文件

为了节省磁盘空间,您可以将导出的文件压缩为 .gz 文件:

复制代码
mysqldump -u your_username -p mydatabase user_manage | gzip > user_manage_backup.sql.gz
导出多个表

如果您想导出多个表,可以在命令中列出所有表名:

复制代码
mysqldump -u your_username -p mydatabase table1 table2 > multiple_tables_backup.sql
导出整个数据库

如果您想导出整个数据库的所有表和数据,可以省略表名:

复制代码
mysqldump -u your_username -p mydatabase > mydatabase_backup.sql

使用 mysqldump 导出的 SQL 文件可以通过 MySQL 的命令行工具或通过其他客户端工具(如 phpMyAdmin 或 MySQL Workbench)导入到数据库中。以下是通过命令行工具导入数据的步骤。

导入 SQL 文件

使用 mysql 命令行工具导入 SQL 文件。以下是几种常见的方法:

方法 1: 直接使用 mysql 命令
复制代码
mysql -u your_username -p target_database < tenant_manage_backup.sql
  • -u your_username:指定您的 MySQL 用户名。
  • -p:提示输入密码。
  • target_database:要导入数据的目标数据库名称。
  • < tenant_manage_backup.sql:从 tenant_manage_backup.sql 文件读取并执行 SQL 语句。
方法 2: 使用 source 命令

首先,进入 MySQL 命令行界面:

复制代码
mysql -u your_username -p

然后,在 MySQL 命令行中选择目标数据库并执行 source 命令:

复制代码
USE target_database;
SOURCE /path/to/tenant_manage_backup.sql;
  • USE target_database;:选择目标数据库。
  • SOURCE /path/to/tenant_manage_backup.sql;:执行 SQL 文件中的所有命令。请确保路径是正确的。
4. 验证导入

导入完成后,您可以验证数据是否正确导入:

复制代码
mysql -u your_username -p target_database -e "SELECT * FROM tenant_manage LIMIT 10;"
注意事项
  • 数据库大小 :对于非常大的数据库,建议使用 --single-transaction--quick 选项以减少锁定时间。
  • 数据一致性:如果需要保证数据一致性,可以在导出时锁定表,但这可能会影响数据库性能。
相关推荐
小陈工3 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
0xDevNull8 小时前
MySQL数据冷热分离详解
后端·mysql
科技小花8 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸8 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain8 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希9 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神9 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员9 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java9 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿9 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb