Bagaimana Menggunakan Penyata Disediakan dengan MySQL dalam Python?

Barbara Streisand
Lepaskan: 2024-11-08 07:48:01
asal
269 orang telah melayarinya

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)
Salin selepas log masuk

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))
Salin selepas log masuk

Barisan ini mencipta rentetan SQL dengan ruang letak ("?" aksara) untuk nilai yang hendak disisipkan.

self.cursor.execute(sql, (d, t, tag, power))
Salin selepas log masuk

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))
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan