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

时间:2010-06-13 07:24:16

标签: mysql

我有一个非常大的数据库,所以我想使用命令提示符导出它,但我不知道如何。

我正在使用WAMP。

17 个答案:

答案 0 :(得分:484)

首先检查命令行是否识别mysql命令。如果没有去指挥&输入:

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

然后使用此命令导出数据库:

mysqldump -u YourUser -p YourDatabaseName > wantedsqlfile.sql

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

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

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

答案 1 :(得分:96)

只需使用以下命令

即可

出口:

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

导入:

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

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

答案 2 :(得分:20)

转到此路径的命令提示符

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

然后使用此命令导出数据库( -p 之后没有空格)

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

答案 3 :(得分:20)

使用以下命令找到您的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]

答案 4 :(得分:13)

导出程序,功能&amp; TRIGGER也是,添加--routines参数:

mysqldump -u YourUser -p YourDatabaseName --routines > wantedsqlfile.sql

答案 5 :(得分:9)

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

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

错误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

相反,请勿使用<将转储导入数据库,同样,您的非utf8字符可能不会被传递;但喜欢来源选项。

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

答案 6 :(得分:7)

我已经在D:驱动器中安装了我的wamp服务器,所以你必须从ur命令行转到以下路径 - &gt;(如果你已经在c:驱动器中安装了你的wamp,那么只需要替换d:wtih 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的用户 密码是phpmyadmin的密码,所以如果你没有为root设置任何密码,那么 db_name是数据库(为其备份数据库) ,backupfile.sql是你想要你备份你的数据库的文件,你也可以将备份文件位置(d:\ backupfile.sql)从你的计算机上的任何其他地方更改

答案 7 :(得分:7)

mysqldump -h [host] -p -u [user] [database name] > filename.sql

localhost中的示例

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

答案 8 :(得分:7)

使用此命令导出数据库,这也包括日期

primitives

(-p之后没有空格)

答案 9 :(得分:6)

Opentuned的答案很棒。 一件小事就是从命令行中删除实际的密码:

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

这可以防止人们在您的历史记录中搜索密码。

答案 10 :(得分:1)

语法

(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 是要存储导出数据库的路径。

答案 11 :(得分:0)

适用于Windows操作系统

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

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

答案 12 :(得分:0)

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

docker exec <container_id/name> / usr / bin / mysqldump -u <db_username> --password = <db_password> db_name> .sql

希望这会有所帮助!

答案 13 :(得分:0)

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

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

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

指定
-p[yourpassword]

希望它有效。

答案 14 :(得分:0)

mysql -u -p 数据库名>fileToPutDatabase

答案 15 :(得分:0)

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

答案 16 :(得分:-3)

您可以使用此脚本从终端导出或导入任何数据库 在此链接中给出: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