Dalam pertanyaan teknikal ini, pengguna mendapatkan panduan tentang cara melaksanakan arahan MySQL melalui skrip shell untuk data automatik pemulihan. Matlamatnya adalah untuk memanfaatkan fail SQL sedia ada untuk memulihkan data yang dikumpul sambil mewujudkan sambungan ke pelayan tertentu.
Untuk melaksanakan proses ini dengan berkesan, pengguna mesti menggunakan bendera -p untuk menghantar kata laluan kepada klien MySQL. Adalah penting untuk ambil perhatian bahawa tiada ruang kosong antara -p dan kata laluan. Kegagalan untuk mematuhi format ini akan menggesa pelanggan meminta kata laluan secara interaktif dan menyalahtafsir hujah arahan berikut sebagai nama pangkalan data.
Sebagai contoh, pertimbangkan penggunaan yang salah:
$ mysql -h "server-name" -u "root" -p "XXXXXXXX" "database-name" < "filename.sql"
Dalam senario ini, sistem akan meminta kata laluan interaktif daripada pengguna dan mentafsirkan XXXXXXXXX sebagai nama pangkalan data, yang membawa kepada mesej ralat berikut:
ERROR 1049 (42000): Unknown database 'XXXXXXXX'
Untuk mengelakkan isu ini, pengguna disyorkan untuk menggunakan fail ~/.my.cnf untuk menyimpan maklumat pengguna dan kata laluan dengan selamat. Ini menghapuskan keperluan untuk memasukkan bukti kelayakan ini pada baris arahan dan memudahkan proses:
[client] user = root password = XXXXXXXX
Setelah konfigurasi ini diwujudkan, arahan MySQL boleh dilaksanakan dengan sintaks berikut:
$ mysql -h "server-name" "database-name" < "filename.sql"
Untuk menyahpepijat potensi isu dalam skrip shell, pengguna boleh memanfaatkan bendera -x, yang menawarkan butiran terperinci jejak pelaksanaan:
$ bash -x myscript.sh
Teknik ini memberikan gambaran menyeluruh tentang cara skrip shell melaksanakan setiap arahan, memudahkan pengenalpastian dan penyelesaian sebarang ralat.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengautomasikan Pemulihan Data MySQL Menggunakan Skrip Shell?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!