我有一个相当大的数据库,所以我想用命令提示符导出它,但我不知道如何。
我正在使用WAMP。
我有一个相当大的数据库,所以我想用命令提示符导出它,但我不知道如何。
我正在使用WAMP。
首先检查您的命令行是否识别mysql命令。如果没有,进入命令并输入:
set path=c:\wamp\bin\mysql\mysql5.1.36\bin
然后使用这个命令导出您的数据库:
mysqldump -u YourUser -p YourDatabaseName > wantedsqlfile.sql
然后系统将提示您输入数据库密码。
这将在执行此命令时将数据库导出到您当前所在的路径
注意:这里有一些关于导入和导出的详细说明
在此路径下进入命令提示符,
C:\Program Files (x86)\MySQL\MySQL服务器5.0\bin>
然后输入以下命令导出数据库(-p后没有空格)
mysqldump -u[用户名]-p[用户名]你的数据库>[存档]wantedsqlfile.sql
我已经在D: drive安装了我的wamp服务器,所以你必须从ur命令行到以下路径->(如果你已经在c: drive安装了wamp,那么只需将D:替换为c: here)
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"
这里根是我的phpmyadmin的用户 密码是phpmyadmin的密码,所以如果你没有为root设置任何密码,在那个地方什么都没有, Db_name是数据库(为哪个数据库进行备份) , backupfile。SQL是你想要备份你的数据库的文件,你也可以改变备份文件的位置(d:\backupfile.sql)从任何其他地方在你的计算机
找到你的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]
只需使用下面的命令,
出口:
mysqldump -u [user] -p [db_name] | gzip > [filename_to_compress.sql.gz]
进口:
gunzip < [compressed_filename.sql.gz] | mysql -u [user] -p[password] [databasename]
注意:关键字“-p”和密码之间没有空格。
mysqldump -h [host] -p -u [user] [database name] > filename.sql
localhost中的示例
mysqldump -h localhost -p -u root cookbook > cookbook.sql
我用过wamp服务器。我试了试
c:\wamp\bin\mysql\mysql5.5.8\bin\mysqldump -uroot -p db_name > c:\somefolder\filename.sql
Root是我mysql的用户名,如果你有密码,请指定:
-p[yourpassword]
希望它有用。
你可以使用下面的命令,
Mysqldump——databases——user=root——password your_db_name > export_into_db.sql
生成的文件将在运行此命令的同一目录中可用。
你可以找到更多关于mysqldump的官方参考:Import Export MySQL DB
注意:使用——databases代替——database,因为不再支持最后一个。
享受:)
语法
(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. exe将是您要导出的数据库的名称。SQL是要存储导出数据库的路径。
windows操作系统:
当你得到错误1064 mysql(42000),而试图执行mysqldump命令,退出当前终端。执行mysqldump命令。
mysql>exit
c:\xampp\mysql\bin>mysqldump -uroot -p --databases [database_name] > name_for_export_db.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
首先 打开命令提示符,然后在CMD中打开bin目录(我希望你知道CMD命令) 进入WAMP程序文件中MySql文件夹的bin目录。
运行命令
mysqldump -u db_username -p database_name > path_where_to_save_sql_file
按enter system将导出特定的数据库并创建SQL文件到给定的位置。
我希望你能做到。 如果你有任何问题,请告诉我。
要导出过程、函数和触发器,添加——routines参数:
mysqldump -u yoru -p你的数据库-routines > wantedsqlfile.sql
给出这个命令来导出您的数据库,这将包括日期
mysqldump -u[username] -p[userpassword] --databases yourdatabase | gzip > /home/pi/database_backup/database_`date '+%m-%d-%Y'`.sql.gz
(-p后没有空格)
我试图转储在docker上运行的db,并提出了以下命令来实现相同的目的:
Docker exec <container_id/name> /usr/bin/mysqldump -u <db_username>——password=<db_password> db_name > .sql
希望这能有所帮助!
所有这些解决方案(使用>重定向器字符)的问题是您从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 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 --no-tablespaces -u username -p pass database_name > db_backup_file.sql
登录您的数据库服务器,然后点击以下命令:-
Mysql -u username -p databasename > exportfilename.sql
然后它会要求输入密码输入密码并按Enter,这将需要一些时间,您的数据库将被导出。
进口:
mysql -u db_username -p newFileName < databasName.sql
出口:
mysqldump -u db_username -p databasName > newFileName.sql