350

重複しないでください!コマンドラインでのエクスポート中にいくつかの機能を探しています

コマンドラインから MySQL データベースとの間で .sql ファイルをエクスポートおよびインポートしたいと考えています。

MySQL に .sql ファイルをエクスポートするコマンドはありますか? では、どのようにインポートすればよいでしょうか。

エクスポート/インポートを行う場合、外部キー チェックの有効化/無効化やテーブル構造のみのエクスポートなどの制約がある場合があります。

これらのオプションを で設定できますmysqldumpか?

オプションの例

ここに画像の説明を入力

4

8 に答える 8

147

次のコマンドを入力して、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 ホスト名を実際のサーバー名または IP アドレスに置き換えます。

$ mysql -u username -p -h 202.54.1.10 databasename < data.sql

データベースをエクスポートするには、次を使用します。

mysqldump -u username -p databasename > filename.sql

それぞれの場合の記号<と記号に注意してください。>

于 2012-07-10T05:56:06.957 に答える
38

既に SQL シェルを実行している場合は、次のsourceコマンドを使用してデータをインポートできます。

use databasename;
source data.sql;
于 2015-01-04T18:05:43.843 に答える
18

データベース全体をファイルにダンプします。

mysqldump -u USERNAME -p password DATABASENAME > FILENAME.sql
于 2012-07-10T05:55:07.937 に答える
17

試す

mysqldump databaseExample > file.sql
于 2012-07-10T05:56:07.653 に答える
8

最高の投稿の後にコメントするほどの評判がないので、ここに追加します。

「|」を使用 ディスクスペースを節約するために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

いくつかの問題/ヒント:

エラー: 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

行 32730 のエラー 1419 (HY000): SUPER 権限がなく、バイナリ ログが有効になっています (安全性の低い log_bin_trust_function_creators 変数を使用することをお勧めします)

# set SET GLOBAL log_bin_trust_function_creators = 1;
# or use super user import data

138 行目のエラー 1227 (42000): アクセスが拒否されました。この操作には (少なくとも 1 つの) SUPER 権限が必要です

# add sed/awk to avoid some privilege issues

この助けを願っています!

于 2017-09-26T03:38:00.007 に答える
2

このスクリプトを使用して、次のリンクにある端末から任意のデータベースをエクスポートまたはインポートできます: 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
于 2016-10-24T21:20:18.930 に答える