MySQL - SELECT * INTO OUTFILE LOCAL?
Dalam pemindahan pelayan baru-baru ini, pangkalan data telah dialihkan ke pelayan lain, menyebabkan yang sebelumnya arahan "PILIH * KE OUTFILE ..." untuk gagal. Walaupun "LOAD DATA INFILE ..." kekal berfungsi, kekurangan pilihan "SELECT INTO OUTFILE LOCAL" membingungkan pengguna.
Penjelasan untuk Kekurangan "SELECT INTO OUTFILE LOCAL"
Tidak seperti "LOAD DATA INFILE" yang dibaca daripada fail setempat pada pelayan, "SELECT INTO OUTFILE" bertujuan untuk menjana fail teks pada pelayan itu sendiri. Disebabkan oleh kebimbangan keselamatan, keupayaan untuk mencipta fail pada pelanggan luaran adalah terhad, oleh itu ketidakupayaan "PILIH KE OUTFILE LOCAL" untuk berfungsi.
Penyelesaian Alternatif
The manual mengesyorkan menggunakan mysql dalam kombinasi dengan ubah hala untuk menjana fail pada hos klien, seperti yang dilihat dalam contoh di bawah:
mysql -h my.db.com -u usrname--password=pass db_name -e 'SELECT foo FROM bar' > /tmp/myfile.txt
Keupayaan MariaDB
Sementara artikel tidak menyebut MariaDB secara eksplisit, isu ini berkaitan dengan tingkah laku MySQL dan tidak menjejaskan fungsi MariaDB secara langsung.
Atas ialah kandungan terperinci Mengapakah 'SELECT * INTO OUTFILE LOCAL' tiada dalam MySQL, dan bagaimana saya boleh mencapai hasil yang sama?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!