如何从命令行导出和导入.sql文件?

AZi*_*key 300 mysql command-line sqlcommand command-line-arguments

我想从命令行导出和导入MySQL数据库的.sql文件.

是否有任何命令在MySQL中导出.sql文件?那我该如何导入呢?

执行导入时,可能存在启用/禁用外键检查仅导出表结构等约束.

我们可以设置这些选项mysqldump

Fra*_*ine 89

键入以下命令以导入sql数据文件:

$ mysql -u username -p -h localhost DATA-BASE-NAME < data.sql
Run Code Online (Sandbox Code Playgroud)

在此示例中,使用vivek作为用户名将'data.sql'文件导入'blog'数据库:

$ mysql -u vivek -p -h localhost blog < data.sql
Run Code Online (Sandbox Code Playgroud)

如果您有专用数据库服务器,请将localhost主机名替换为实际服务器名称或IP地址,如下所示:

$ mysql -u username -p -h 202.54.1.10 databasename < data.sql
Run Code Online (Sandbox Code Playgroud)

要导出数据库,请使用以下命令:

mysqldump -u username -p databasename > filename.sql
Run Code Online (Sandbox Code Playgroud)

请注意每种情况下的符号<>符号.


Dav*_*edy 29

如果您已经在运行SQL shell,则可以使用该source命令导入数据:

use databasename;
source data.sql;
Run Code Online (Sandbox Code Playgroud)


Pod*_*.io 23

除非在转储单个数据库时明确说明,否则mysqldump不会转储数据库事件,触发器和例程;

mysqldump -uuser -p db_name --events --triggers --routines > db_name.sql
Run Code Online (Sandbox Code Playgroud)


Ume*_*til 18

那你可以使用下面的命令导出,

mysqldump --database --user = root --password your_db_name> export_into_db.sql

生成的文件将在您运行此命令的同一目录中可用.

现在使用命令登录mysql,

mysql -u [用户名] -p

然后使用"source"命令和文件路径.


You*_*cha 15

尝试

mysqldump databaseExample > file.sql
Run Code Online (Sandbox Code Playgroud)


小智 8

将整个数据库转储到文件:

mysqldump -u USERNAME -p password DATABASENAME > FILENAME.sql
Run Code Online (Sandbox Code Playgroud)


How*_*.TH 8

因为我没有足够的声誉在最高帖子后发表评论,所以我在这里补充。

使用“|” 在linux平台上节省磁盘空间。

谢谢@Hariboo,添加事件/触发器/路由参数

mysqldump -x -u [uname] -p[pass]  -C --databases db_name  --events --triggers --routines | sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/ '  | awk '{ if (index($0,"GTID_PURGED")) { getline; while (length($0) > 0) { getline; } } else { print $0 } }'  | grep -iv 'set @@' | trickle -u 10240 mysql -u username -p -h localhost DATA-BASE-NAME
Run Code Online (Sandbox Code Playgroud)

一些问题/提示:

错误:......使用锁定表时不存在

# --lock-all-tables?-x , this parameter is to keep data consistency because some transaction may still be working like schedule.
# also you need check and confirm: grant all privileges on *.* to root@"%" identified by "Passwd";
Run Code Online (Sandbox Code Playgroud)

第 866 行的 ERROR 2006 (HY000):MySQL 服务器已消失 mysqldump:写入时出现 errno 32

# set this values big enough on destination mysql server, like: max_allowed_packet=1024*1024*20
# use compress parameter '-C'
# use trickle to limit network bandwidth while write data to destination server
Run Code Online (Sandbox Code Playgroud)

第 32730 行的 ERROR 1419 (HY000):您没有 SUPER 权限并且启用了二进制日志记录(您可能想要使用安全性较低的 log_bin_trust_function_creators 变量)

# set SET GLOBAL log_bin_trust_function_creators = 1;
# or use super user import data
Run Code Online (Sandbox Code Playgroud)

第 138 行的 ERROR 1227 (42000):访问被拒绝;您需要(至少其中之一)此操作 mysqldump 的 SUPER 权限:Got errno 32 on write

# add sed/awk to avoid some privilege issues
Run Code Online (Sandbox Code Playgroud)

希望这有帮助!