Rumah >pangkalan data >tutorial mysql >Bagaimana Menggunakan Penyata Disediakan dengan MySQL dalam Python?

Bagaimana Menggunakan Penyata Disediakan dengan MySQL dalam Python?

Barbara Streisand
Barbara Streisandasal
2024-11-08 07:48:01340semak imbas

How to Use Prepared Statements with MySQL in Python?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn