Rumah >pangkalan data >tutorial mysql >Mengapa Kemas Kini MySQL Saya Tidak Berlaku dalam Python?

Mengapa Kemas Kini MySQL Saya Tidak Berlaku dalam Python?

DDD
DDDasal
2024-11-04 11:10:02868semak imbas

Why Are My MySQL Updates Not Committing in Python?

Menyelesaikan Masalah Pertanyaan Kemas Kini MySQL dalam Python

Dalam Python, apabila melakukan operasi kemas kini pada pangkalan data MySQL menggunakan modul MySQLdb, adalah penting untuk melakukan perubahan untuk memastikan ia berterusan dengan jayanya. Jika tidak, kemas kini mungkin kelihatan seperti melaksanakan tetapi sebenarnya tidak mengubah suai pangkalan data.

Pertimbangkan kod berikut:

<code class="python">dbb = MySQLdb.connect(host="localhost", user="user", passwd="pass", db="database")
curb = dbb.cursor()
curb.execute("UPDATE RadioGroups SET CurrentState=1 WHERE RadioID=11")
print "Row(s) were updated :" + str(curb.rowcount)
curb.close()</code>

Sementara kod di atas mengambil dan mencetak bilangan baris yang terjejas dengan betul, pangkalan data itu sendiri tetap tidak berubah. Untuk melakukan perubahan dan menjadikannya kekal, tambahkan pernyataan berikut selepas melaksanakan pertanyaan kemas kini:

<code class="python">dbb.commit()</code>

Barisan ini mengarahkan pelayan MySQL untuk memuktamadkan semua pengubahsuaian yang belum selesai dan menggunakannya pada pangkalan data. Tanpa langkah ini, sebarang kemas kini yang dibuat dalam sesi kursor tidak akan berterusan setelah kursor ditutup.

Ingat, melakukan perubahan adalah penting untuk semua operasi SQL yang mengubah suai data, seperti INSERT, UPDATE dan DELETE. Dengan memasukkan dbb.commit();, anda memastikan bahawa perubahan anda ditunjukkan secara kekal dalam pangkalan data.

Atas ialah kandungan terperinci Mengapa Kemas Kini MySQL Saya Tidak Berlaku 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