コマンドラインからMySQLデータベースとの間で.sqlファイルをエクスポートおよびインポートしたい。
MySQLに.sqlファイルをエクスポートするためのコマンドはありますか?それではどうやってそれをインポートするのですか?
インポートをするとき、enable/disable 外部キーチェック または テーブル構造のみエクスポート のような制約があるかもしれません。
options をmysqldump
で設定できますか?
次のコマンドを入力してSQLデータファイルをインポートします。
$ mysql -u username -p -h localhost DATA-BASE-NAME < data.sql
この例では、vivekをユーザー名として使用して、 'data.sql'ファイルを 'blog'データベースにインポートします。
$ mysql -u vivek -p -h localhost blog < data.sql
専用のデータベースサーバーがある場合は、次のようにlocalhost hostnameを実際のサーバー名またはIPアドレスに置き換えます。
$ mysql -u username -p -h 202.54.1.10 databasename < data.sql
データベースをエクスポートするには、次のようにします。
mysqldump -u username -p databasename > filename.sql
それぞれの場合に<
と>
の記号に注意してください。
すでにSQLシェルを実行している場合は、source
コマンドを使用してデータをインポートできます。
use databasename;
source data.sql;
個々のデータベースをダンプするときに明示的に述べられていない限り、mysqldumpはデータベースイベント、トリガー、およびルーチンをダンプしません。
mysqldump -uuser -p db_name --events --triggers --routines > db_name.sql
試します
mysqldump databaseExample > file.sql
まあ、あなたはエクスポートするために以下のコマンドを使用することができます、
mysqldump --database --user = root --password your_db_name> export_into_db.sql
生成されたファイルは、このコマンドを実行したのと同じディレクトリにあります。
コマンドを使ってmysqlにログインします。
mysql -u [ユーザー名] -p
次に、ファイルパスを指定して "source"コマンドを使用します。
データベース全体をファイルにダンプします。
mysqldump -u USERNAME -p password DATABASENAME > FILENAME.sql
私は最高の投稿の後にコメントするのに十分な評判がないので、ここに付け加えます。
'|'を使用Linuxプラットフォームではディスク容量を節約します。
thx @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
いくつかの問題/ヒント:
Error:LOCK TABLESを使用しているときは......存在しません
# --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";
エラー2006(HY000)、ライン866: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
エラー1419(HY000)、行32730:あなたにはSUPER特権がなく、バイナリロギングが有効になっています(あなたは おそらく より安全でないlog_bin_trust_function_creators変数を使用したいです)
# set SET GLOBAL log_bin_trust_function_creators = 1;
# or use super user import data
138行目のエラー1227(42000):アクセスが拒否されました。この操作にはSUPER特権(少なくとも1つ)が必要です。mysqldump:書き込み時にerrno 32を取得しました。
# add sed/awk to avoid some privilege issues
この助けを願っています!
あなたはこれを使用することができます エクスポートまたはインポートするスクリプト このリンクで与えられた端末から任意のデータベース: 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