首頁 >後端開發 >Python教學 >如何修復參數化 SQL 查詢中的「類型錯誤:字串格式化期間未轉換所有參數」?

如何修復參數化 SQL 查詢中的「類型錯誤:字串格式化期間未轉換所有參數」?

Barbara Streisand
Barbara Streisand原創
2024-12-06 06:33:14282瀏覽

How to Fix

參數化SQL 查詢:解決「TypeError:在字串格式化期間未轉換所有參數」

在參數化SQL 查詢中,確保正確的操作至關重要語法和資料轉換以避免錯誤。嘗試在參數化查詢中使用字串格式時,可能會出現錯誤「TypeError:字串格式期間未轉換所有參數」。

要解決此問題,請避免使用 %s 作為參數的佔位符。相反,請將參數作為單獨的列表傳遞給execute() 方法。例如:

import MySQLdb as mdb

class Test:
    def check(self, search):
        con = mdb.connect(...)
        cur = con.cursor()
        cur.execute("SELECT * FROM records WHERE email LIKE %s", [search])
        ...

透過在列表中傳遞搜索,您明確指示應將其視為單獨的參數以進行轉換並包含在查詢中。這種方法可確保所有參數都正確轉換並在查詢中使用。

以上是如何修復參數化 SQL 查詢中的「類型錯誤:字串格式化期間未轉換所有參數」?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn