Heim > Datenbank > MySQL-Tutorial > Hauptteil

Warum schlägt meine Python-MySQL-Update-Anweisung fehl und wie kann ich das Problem beheben?

Mary-Kate Olsen
Freigeben: 2024-11-08 13:26:02
Original
667 Leute haben es durchsucht

Why is My Python MySQL Update Statement Failing, and How Can I Fix It?

Python-MySQL-Update-Anweisung mit Variablen korrigieren

Beim Versuch, MySQL-Datensätze mithilfe einer Python-Update-Anweisung zu aktualisieren, können bei Benutzern Fehler auftreten. Um dieses Problem zu beheben, ist es wichtig, die Syntax zu überprüfen und ihre ordnungsgemäße Anwendung sicherzustellen.

Falsche Aussage:

cursor.execute ("UPDATE tblTableName SET Year=%s" % Year ", Month=%s" % Month ", Day=%s" % Day ", Hour=%s" % Hour ", Minute=%s" Minute "WHERE Server=%s " % ServerID)
Nach dem Login kopieren

Analyse:

Die falsche Anweisung schlägt aufgrund einer falschen Zeichenfolgenverkettung und eines fehlenden Platzhalters für die Variable „Minute“ fehl. Die korrekte Schreibweise dieser Aussage lautet:

Richtige Aussage:

cursor.execute ("""
   UPDATE tblTableName
   SET Year=%s, Month=%s, Day=%s, Hour=%s, Minute=%s
   WHERE Server=%s
""", (Year, Month, Day, Hour, Minute, ServerID))
Nach dem Login kopieren

Alternative Syntax:

Alternativ: String-Manipulation kann verwendet werden:

cursor.execute ("UPDATE tblTableName SET Year=%s, Month=%s, Day=%s, Hour=%s, Minute=%s WHERE Server='%s' " % (Year, Month, Day, Hour, Minute, ServerID))
Nach dem Login kopieren

Achtung:

Die alternative Syntax funktioniert zwar möglicherweise, es wird jedoch dringend davon abgeraten, da Ihre Anwendung dadurch anfällig für SQL-Injection-Angriffe wird . Der empfohlene Ansatz ist die Verwendung von Platzhaltern, wie in der richtigen Anweisung dargestellt.

Datenbankkompatibilität:

Darüber hinaus können einige Datenbank-Backends unterschiedliche Konventionen zum Ersetzen von Zeichenfolgen haben. Beispielsweise verwendet SQLite „?“ anstelle von „%s“ für Platzhalter.

Das obige ist der detaillierte Inhalt vonWarum schlägt meine Python-MySQL-Update-Anweisung fehl und wie kann ich das Problem beheben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!