如何使用命令提示符导出 mysql 数据库?

Posted

技术标签:

【中文标题】如何使用命令提示符导出 mysql 数据库?【英文标题】:How to export a mysql database using Command Prompt? 【发布时间】:2011-03-03 03:56:49 【问题描述】:

我有一个很大的数据库,所以我想使用命令提示符将其导出,但我不知道如何操作。

我正在使用 WAMP。

【问题讨论】:

DOS?你用的是Windows 98吗?还是你的意思是命令提示符? 在你使用 wamp 时,你还应该有 phpmyadmin,带有导出选项 【参考方案1】:

首先检查你的命令行是否能识别 mysql 命令。如果没有转到命令并输入:

set path=c:\wamp\bin\mysql\mysql5.1.36\bin

然后使用这个命令导出你的数据库:

mysqldump -u YourUser -p YourDatabaseName > wantedsqlfile.sql

然后会提示您输入数据库密码

这会将数据库导出到您当前所在的路径,同时执行此命令

注意:Here are some detailed instructions 关于导入和导出

【讨论】:

我收到此错误 mysqldump: Got error: 1556: You can't use locks with log tables。使用 LOCK TABLES 时 @Ammad,您可能也在尝试转储日志表。您需要排除它们。我建议用更多细节问一个不同的问题。如果你想让我研究它,也给我链接。我很乐意研究它。 我从 VSCODE 扩展运行它,它显示 Error: ER_PARSE_ERROR: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'mysqldump -u mypu -p mypu>abc.sql' at line 1,我有 5.7.20 版本的 mysql 如果你不想在windows中全局设置变量路径(像我一样)只需cd C:\wamp\bin\mysql\mysql(mysql version)\bin\ 然后运行你的mysqldump命令。【参考方案2】:

在此路径下进入命令提示符,

C:\Program Files (x86)\MySQL\MySQL Server 5.0\bin>

然后给出这个命令来导出你的数据库(-p后面没有空格

mysqldump -u[username] -p[userpassword] yourdatabase > [filepath]wantedsqlfile.sql

【讨论】:

ERROR 1064 (42000):您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行 mysql> mysqldump -h 10.0.0.31 的“mysqldump -h 10.0.0.31 -p -u asfuser asfd8crm > var/downloads/db.sql”附近​​使用正确的语法-p -u asfuser asfd8crm > var/downloads【参考方案3】:

我已经在 D: 驱动器中安装了我的 wamp 服务器,所以你必须从你的命令行转到以下路径->(如果你已经在 c: 驱动器中安装了你的 wamp,那么只需将 d: 替换为 c: 这里)

D:\>cd wamp
D:\wamp>cd bin
D:\wamp\bin>cd mysql
D:\wamp\bin\mysql>cd mysql5.5.8 (whatever ur verserion will be displayed here use keyboard Tab button and select the currently working mysql version on your server if you have more than one mysql versions)
D:\wamp\bin\mysql\mysql5.5.8>cd bin
D:\wamp\bin\mysql\mysql5.5.8\bin>mysqldump -u root -p password db_name > "d:\backupfile.sql"

这里 root 是我的 phpmyadmin 的用户 password 是 phpmyadmin 的密码,所以 如果你没有为 root 设置任何密码,那么在那个地方什么都不输入, db_name 是数据库(您为哪个数据库进行备份) ,backupfile.sql 是您想要备份您的数据库的文件,您还可以将备份文件位置(d:\backupfile.sql)从您计算机上的任何其他位置更改

【讨论】:

在我发现的所有方法中,这个答案是唯一对我有用的方法。我使用的是 MySQL 5.6 版,因此命令提示符的路径是 ...\MySQL\MySQL Server 5.6\bin。您将不得不使用您的 MySQL 管理员用户名和密码,为特定数据库指定的那些将不起作用。谢谢萨钦。即使是 v.5.6 的 MySQL 手册中的说明也不起作用。那里的语法不完整。 它真的适用于-ppassword 之间的空格吗?【参考方案4】:

使用以下命令找到您的 mysql 实例:

which mysql

如果正确,则使用以下内容导出(否则导航到 bin 中 mamp 文件夹中的 mysql 实例):

mysqldump -u [username] -p [password] [dbname] > filename.sql

如果你想同时压缩它:

mysqldump -u [username] -p [password] [db] | gzip > filename.sql.gz

然后你可以在服务器之间移动这个文件:

scp user@xxx.xxx.xxx.xxx:/path_to_your_dump/filename.sql.gz your_detination_path/

(其中 xxx.xxx.xxx.xxx 是服务器 IP 地址)

然后将其导入:

gunzip filename.sql.gz | mysql -u [user] -p [password] [database]

【讨论】:

再次,W AMP => Windows。 which 是一个 Linux 命令。 gunzip / gzip 未与 Windows 捆绑在一起 - 并且可能不可用。 scp...你明白了。 Opentuned 的答案很棒。一件小事是从命令行中删除实际的password:mysqldump -u [username] -p [dbname] > filename.sql 这可以防止人们搜索您的历史记录以获取密码。 @Opentuned,Linux 迷信是怎么回事? for -p [密码] 必须靠近例如:mysqldump -u tutorials -p'mypassword' -h 127.0.0.1 database_name > file_backup_database_name_.sql 警告:在命令行界面上使用密码可能不安全。 ERROR 1064 (42000):您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行 mysql> mysqldump -h 10.0.0.31 的 'mysqldump -h 10.0.0.31 -p -u asfuser asfd8crm > var/downloads/db.sql' 附近使用正确的语法-p -u asfuser asfd8crm > var/downloads【参考方案5】:

只需使用以下命令,

出口:

mysqldump -u [user] -p [db_name] | gzip > [filename_to_compress.sql.gz] 

进口:

gunzip < [compressed_filename.sql.gz]  | mysql -u [user] -p[password] [databasename] 

注意:关键字“-p”和您的密码之间没有空格。

【讨论】:

我认为您错过了他使用 WAMP 的事实 - Windows... gunzip / gzip 未与 Windows 捆绑在一起。安装一些东西后可能会运行你的命令,但我认为你已经错过了这个事实。 指定gzip -9 会使生成的文件更小一些,因为使用了最大压缩。【参考方案6】:
mysqldump -h [host] -p -u [user] [database name] > filename.sql

本地主机中的示例

mysqldump -h localhost -p -u root cookbook > cookbook.sql

【讨论】:

ERROR 1064 (42000):您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行 mysql> mysqldump -h 10.0.0.31 的“mysqldump -h 10.0.0.31 -p -u asfuser asfd8crm > var/downloads/db.sql”附近​​使用正确的语法-p -u asfuser asfd8crm > var/downloads【参考方案7】:

我使用过 wamp 服务器。我试过了

c:\wamp\bin\mysql\mysql5.5.8\bin\mysqldump -uroot -p db_name > c:\somefolder\filename.sql

root 是我的 mysql 用户名,如果您有任何密码,请指定:

-p[yourpassword]

希望它有效。

【讨论】:

--如果您想输入密码,则需要使用密码【参考方案8】:

你可以使用下面的命令,

mysqldump --databases --user=root --password your_db_name &gt; export_into_db.sql

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

您可以在mysqldump 的官方参考中找到更多信息:Import Export MySQL DB

注意:使用--databases 而不是--database,因为不再支持最后一个。

享受:)

【讨论】:

对于那些出现“使用LOCK TABLES时拒绝访问”这样的错误,您应该在命令中添加“--single-transaction”参数。 我收到了一个错误 mysqldump: [ERROR] unknown option '--database',但排除了 --database 它已经起作用了。 @Skyrpex 谢谢,这就是我一直在寻找的解决方案。【参考方案9】:

语法

(mysqldump.exe full path) -u (user name) -p (password) (database name) > (export database file full path)

示例

c:>d:\wamp\bin\mysql\mysql5.6.12\bin\mysqldump.exe -u root -p mydbname > d:\mydb.sql

其中 d:\wamp\bin\mysql\mysql5.6.12\bin\mysqldump.exe 将是您的实际 mysqldump.exe 路径,mydbname 是您要导出的数据库,d:\mydb.sql 是您要存储导出数据库的路径。

【讨论】:

【参考方案10】:

适用于 Windows 操作系统

当您在尝试执行 mysqldump 命令时收到错误 1064 mysql (42000) 时,请从当前终端退出。并执行 mysqldump 命令。

mysql>exit 
c:\xampp\mysql\bin>mysqldump -uroot -p --databases [database_name] > name_for_export_db.sql

【讨论】:

【参考方案11】:

您可以使用此脚本从终端导出或导入任何数据库 在此链接中给出:https://github.com/Ridhwanluthra/mysql_import_export_script/blob/master/mysql_import_export_script.sh

echo -e "Welcome to the import/export database utility\n"
echo -e "the default location of mysqldump file is: /opt/lampp/bin/mysqldump\n"
echo -e "the default location of mysql file is: /opt/lampp/bin/mysql\n"
read -p 'Would like you like to change the default location [y/n]: ' location_change
read -p "Please enter your username: " u_name
read -p 'Would you like to import or export a database: [import/export]: ' action
echo

mysqldump_location=/opt/lampp/bin/mysqldump
mysql_location=/opt/lampp/bin/mysql

if [ "$action" == "export" ]; then
    if [ "$location_change" == "y" ]; then
        read -p 'Give the location of mysqldump that you want to use: ' mysqldump_location
        echo
    else
        echo -e "Using default location of mysqldump\n"
    fi
    read -p 'Give the name of database in which you would like to export: ' db_name
    read -p 'Give the complete path of the .sql file in which you would like to export the database: ' sql_file
    $mysqldump_location -u $u_name -p $db_name > $sql_file
elif [ "$action" == "import" ]; then
    if [ "$location_change" == "y" ]; then
        read -p 'Give the location of mysql that you want to use: ' mysql_location
        echo
    else
        echo -e "Using default location of mysql\n"
    fi
    read -p 'Give the complete path of the .sql file you would like to import: ' sql_file
    read -p 'Give the name of database in which to import this file: ' db_name
    $mysql_location -u $u_name -p $db_name < $sql_file
else
    echo "please select a valid command"
fi

【讨论】:

【参考方案12】:

首先 打开命令提示符,然后在 cmd 中打开 bin 目录(希望您了解 cmd 命令) 转到 WAMP 程序文件中 MySql 文件夹的 bin 目录。

运行命令

mysqldump -u db_username -p database_name > path_where_to_save_sql_file

按回车系统将导出特定数据库并创建sql文件到给定位置。

我希望你明白了 :) 如果您有任何问题,请告诉我。

【讨论】:

我的朋友我试着解释一下过程。而不是直接指挥 ERROR 1064 (42000):您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行 mysql> mysqldump -h 10.0.0.31 的 'mysqldump -h 10.0.0.31 -p -u asfuser asfd8crm > var/downloads/db.sql' 附近使用正确的语法-p -u asfuser asfd8crm > var/downloads【参考方案13】:

要同时导出 PROCEDURE、FUNCTION 和 TRIGGER,请添加 --routines 参数:

mysqldump -u YourUser -p YourDatabaseName --routines &gt; wantedsqlfile.sql

【讨论】:

开关--routines 与众不同:) 任何提示如何仅导出过程、函数和触发器?对于那些忘记了开关并在没有“算法”的情况下导出“纯”数据库的人:) 顺便说一句,转储事件调度程序事件需要开关--events,并且除非指定--skip-triggers,否则始终导出触发器(根据7.4.5.3 Dumping Stored Programs)【参考方案14】:

给出这个命令来导出你的数据库,这也包括日期

mysqldump -u[username] -p[userpassword] --databases yourdatabase | gzip > /home/pi/database_backup/database_`date '+%m-%d-%Y'`.sql.gz

(-p 后面没有空格)

【讨论】:

注意,指定--databases 将插入语句为CREATE DATABASE XYZ;USE XYZ;,这在将SQL 导入另一个名称的数据库时并不方便...【参考方案15】:

我试图获取在 docker 上运行的数据库的转储,并想出了以下命令来实现相同的目的:

docker exec &lt;container_id/name&gt; /usr/bin/mysqldump -u &lt;db_username&gt; --password=&lt;db_password&gt; db_name > .sql

希望这会有所帮助!

【讨论】:

【参考方案16】:

所有这些解决方案的问题(使用&gt; 重定向器字符)是您从标准输出写入转储,这可能会破坏数据库中某些字符的编码。

如果您遇到字符编码问题。如:

ERROR 1064 (42000):您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以了解在附近使用的正确语法 ...

那么,您必须使用-r 选项来写入文件。

MySQL

mysqldump -u user -pyour-password-without-space-between-letter-p-and-your-password --default-character-set=utf8 --host $HOST database-name -r dump.sql

使用 Docker

docker exec --rm -v $pwd:dump -it mysql:5:7 mysqldump -u user -pyour-password-without-space-between-letter-p-and-your-password --default-character-set=utf8 --host $HOST database-name -r dump/dump.sql

注意:这会将当前路径挂载为实例内的转储。

我们找到了答案here

相反,不要使用&lt; 将您的转储导入数据库,同样,您的非utf8 字符可能无法传递;但更喜欢源选项。

mysql -u user -pYourPasswordYouNowKnowHow --default-character-set=utf8 your-database
mysql> SET names 'utf8'
mysql> SOURCE dump.sql

【讨论】:

注意在命令中写入密码。它将保存在 bash 历史记录中,并且可能会破坏安全性。【参考方案17】:

mysql -u -p 数据库名>fileToPutDatabase

【讨论】:

【参考方案18】:

mysqldump --no-tablespaces -u user -ppass dbname > db_backup_file.sql

【讨论】:

虽然此代码可能会解决问题,但 including an explanation 关于如何以及为什么解决问题将真正有助于提高您的帖子质量,并可能导致更多的赞成票。请记住,您正在为将来的读者回答问题,而不仅仅是现在提出问题的人。请edit您的回答添加解释并说明适用的限制和假设。

以上是关于如何使用命令提示符导出 mysql 数据库?的主要内容,如果未能解决你的问题,请参考以下文章

mysql如何导入sql文件

从 XAMPP 导出 MySQL 数据库 [关闭]

为啥使用Mysql命令source导入.sql文件时总是出错?

Linux 导入导出 MySQL 数据库命令

通过命令修改mysql的提示符

mysql导入导出命令