SQL ステートメントですべてのパラメータが使用されていません (Python、MySQL) 質問する

SQL ステートメントですべてのパラメータが使用されていません (Python、MySQL) 質問する

次の Python コードでエラーが発生します。

import mysql.connector
cnx = mysql.connector.connect(user='root', password='',
                          host='127.0.0.1',
                          database='DB')
cursor = cnx.cursor()

Name = "James"
Department = "Finance"
StartYear = 2001
CurrentPos = 2001
Link = ""

add_user = ("INSERT INTO DB.tbluser "
       "(username, department, startyear, currentpos, link) "
       "VALUES (%s, %s, %d, %d, %s)")
data_user = (Name, Department, StartYear, CurrentPos, Link)
cursor.execute(add_user, data_user)
cnx.commit()
cursor.close()
cnx.close()

エラーメッセージは

mysql.connector.errors.ProgrammingError: Not all parameters were used in the SQL statement

理由が分かりますか?

ベストアンサー1

パラメータマーカーは%sではありません%d

add_user = """INSERT INTO DB.tbluser 
              (username, department, startyear, currentpos, link) 
              VALUES (%s, %s, %s, %s, %s)"""

注意:パラメータマーカーが使用する は、 Python 文字列フォーマットで使用されるmysql.connectorと同じように見えるかもしれません%sが、その関係は単なる偶然です。一部のデータベース アダプタは を好みoursql、の代わりに をパラメータ マーカーとしてsqlite3使用します。?%s

おすすめ記事