Menggunakan Penyata Disediakan dengan MySQL dalam Python: Penjelasan Terperinci
Memahami Sintaks
Penyata yang disediakan dalam MySQL menawarkan cara yang lebih cekap dan selamat untuk melaksanakan pertanyaan dengan memisahkan pertanyaan fasa persediaan daripada fasa pelaksanaan. Apabila menggunakan pernyataan yang disediakan, adalah penting untuk mengikuti sintaks yang betul untuk mengelakkan kemungkinan ralat.
Penjelasan Ralat
Dalam coretan kod anda, anda menghadapi ralat kerana anda menggunakan sintaks yang salah untuk pernyataan yang disediakan. Berikut ialah pecahan isu:
sql = "PREPARE stmt FROM ' INSERT INTO {} (date, time, tag, power) VALUES (?, ?, ?, ?)'".format(self.db_scan_table) self.cursor.execute(sql)
Barisan ini cuba menyediakan pernyataan bernama "stmt" menggunakan rentetan SQL. Walau bagaimanapun, modul MySQLdb Python tidak menyokong arahan "PREPARE" dan "EXECUTE" secara langsung.
Penyelesaian Menggunakan MySQLdb
Untuk menggunakan pernyataan yang disediakan dengan MySQLdb, anda perlu untuk menggunakan pendekatan yang sedikit berbeza:
sql = ('INSERT INTO {} (date, time, tag, power) VALUES (%s, %s, %s, %s)'.format(self.db_scan_table))
Barisan ini mencipta rentetan SQL dengan ruang letak ("?" aksara) untuk nilai yang hendak disisipkan.
self.cursor.execute(sql, (d, t, tag, power))
Baris ini melaksanakan pernyataan yang disediakan menggunakan nilai yang ditentukan dalam tupel. MySQLdb secara automatik menyediakan pernyataan dan mengendalikan pelaksanaan.
Menggunakan MySQL Connector/Python
Cara yang lebih moden dan cekap untuk menggunakan pernyataan yang disediakan dengan MySQL dalam Python ialah menggunakan Penyambung MySQL/Python. Ia menawarkan pilihan "prepare=True" yang jelas dalam kilang kursor:
cursor = conn.cursor(prepared=True) sql = ('INSERT INTO {} (date, time, tag, power) VALUES (%s, %s, %s, %s)'.format(self.db_scan_table)) cursor.execute(sql, (d, t, tag, power))
Pendekatan ini memberikan kawalan yang lebih besar ke atas pernyataan yang disediakan dan disyorkan untuk prestasi dan keselamatan yang lebih baik.
Atas ialah kandungan terperinci Bagaimana Menggunakan Penyata Disediakan dengan MySQL dalam Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!