Dalam persekitaran MySQL berbilang pelayan, mungkin perlu untuk menyertai jadual merentas pangkalan data yang berada pada pelayan fizikal yang berbeza. Artikel ini meneroka cara untuk mencapai gabungan antara pelayan ini menggunakan modul MySQLDB Python.
MySQL menyediakan enjin storan FEDERATED, yang membolehkan jadual ditakrifkan merentas berbilang pangkalan data pada pelayan yang berbeza. Pendekatan ini melibatkan mencipta pangkalan data "bersekutu" yang mengandungi rujukan kepada jadual pada pelayan jauh. Untuk menubuhkan persekutuan, gunakan sintaks berikut:
CREATE TABLE federated_table ( ... ) ENGINE=FEDERATED DEFAULT CONNECTION='connection_string'
Gantikan "connection_string" dengan parameter sambungan untuk pelayan jauh.
Sebagai alternatif kepada enjin storan FEDERATED, anda boleh menggunakan pangkalan data perantaraan sebagai lapisan integrasi data. Wujudkan sambungan ke pangkalan data perantaraan dan cipta pandangan yang merujuk jadual dalam pangkalan data jauh. Kemudian, lakukan cantuman pada paparan dalam pangkalan data perantaraan.
Menggunakan modul MySQLDB Python untuk kedua-dua pendekatan, kod berikut menunjukkan gabungan antara pelayan:
import MySQLdb # Establish connections to the remote databases conn_server1 = MySQLdb.connect(...) conn_server2 = MySQLdb.connect(...) # Create cursors cursor1 = conn_server1.cursor() cursor2 = conn_server2.cursor() # Intermediate database approach # Create a view in the intermediate database cursor1.execute(...) # Perform the join on the view cursor1.execute(...) # FEDERATED approach # Create a federated table cursor1.execute(...) # Perform the join on the federated table cursor1.execute(...)
Penyertaan antara pelayan dalam MySQL boleh dicapai sama ada menggunakan enjin storan FEDERATED atau pangkalan data perantaraan sebagai lapisan integrasi data. Kedua-dua kaedah membenarkan penyepaduan dan manipulasi data yang lancar merentas berbilang pangkalan data pada pelayan yang berbeza.
Atas ialah kandungan terperinci Bagaimana untuk Sertai Pangkalan Data MySQL pada Pelayan Berbeza Menggunakan Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!