我的数据库很大,因此我想使用命令提示符将其导出,但是我不知道如何。
我正在使用WAMP。
我的数据库很大,因此我想使用命令提示符将其导出,但是我不知道如何。
我正在使用WAMP。
Answers:
首先检查您的命令行是否可以识别mysql命令。如果没有,请输入以下命令并输入:
set path=c:\wamp\bin\mysql\mysql5.1.36\bin
然后使用此命令导出数据库:
mysqldump -u YourUser -p YourDatabaseName > wantedsqlfile.sql
然后将提示您输入数据库密码。
执行此命令时,这会将数据库导出到您当前所在的路径
-p
和之间没有空格thepassword
。
-p
,然后会提示您输入密码。这样,您避免保存密码,例如.bash_history
只需使用以下命令,
出口:
mysqldump -u [user] -p [db_name] | gzip > [filename_to_compress.sql.gz]
导入:
gunzip < [compressed_filename.sql.gz] | mysql -u [user] -p[password] [databasename]
注意:关键字“ -p”和密码之间没有空格。
gzip -9
将使生成的文件小一些,因为使用了最大压缩率。
首先打开命令提示符,然后在cmd中打开bin目录(我希望您知道cmd命令),然后转到WAMP程序文件中MySql文件夹的bin目录。
运行命令
mysqldump -u db_username -p database_name > path_where_to_save_sql_file
按回车系统将导出特定的数据库并创建sql文件到给定的位置。
我希望你明白了:)如果您有任何问题,请告诉我。
好吧,您可以使用以下命令,
mysqldump --databases --user=root --password your_db_name > export_into_db.sql
并且生成的文件将在您运行该命令的目录中可用。
您可以在以下官方参考中找到更多信息mysqldump
:导入导出MySQL DB
注意:使用--databases
而不是,--database
因为不再支持最后一个。
请享用 :)
mysqldump: [ERROR] unknown option '--database'
但是机智排除了--database
它。
使用以下命令找到您的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]
password
从命令行删除实际值:mysqldump -u [用户名] -p [dbname]> filename.sql这可以防止人们在您的历史记录中搜索密码。
mysqldump -u tutorials -p'mypassword' -h 127.0.0.1 database_name > file_backup_database_name_.sql
警告:在命令行界面上使用密码可能不安全。
我已将Wamp服务器安装在D:驱动器中,因此您必须从ur命令行->转到以下路径(如果您已在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的用户,密码是phpmyadmin 的密码,因此,如果您尚未为root设置任何密码,而在那个地方没有任何输入,则 db_name是数据库(要进行备份的数据库),backupfile.sql是您要在其中备份数据库文件的文件,还可以将备份文件位置(d:\ backupfile.sql)从更改为计算机上的任何其他位置
-p
和和之间的空格真的起作用password
吗?
所有这些解决方案的问题(使用 >
重定向器字符)是您从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
注意:这会将当前路径作为转储安装在实例内部。
我们在这里找到了答案
相反,请勿使用<
将转储导入数据库的方法,同样,您的非utf8字符可能不会被传递;但喜欢来源选项。
mysql -u user -pYourPasswordYouNowKnowHow --default-character-set=utf8 your-database
mysql> SET names 'utf8'
mysql> SOURCE dump.sql
(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是其中的路径您要存储导出的数据库。
我正在尝试对正在docker上运行的数据库进行转储,并提出了以下命令来实现相同的目的:
泊坞窗exec <container_id/name>
/ usr / bin / mysqldump -u <db_username>
--password =<db_password>
db_name
> .sql
希望这可以帮助!
您可以使用此脚本从此链接提供的终端中导出或导入任何数据库: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