Maison >développement back-end >Tutoriel Python >Pourquoi mon code SQLite3 génère-t-il une erreur « Liaisons incorrectes fournies » ?
Erreur SQLite3 : liaisons incorrectes fournies
Lors de l'exécution de requêtes SQL avec des paramètres de liaison, il est crucial de s'assurer que le nombre correct de liaisons est fourni. Dans le code donné, l'erreur suivante est rencontrée :
sqlite3.ProgrammingError: Incorrect number of bindings supplied. The current statement uses 1, and there are 74 supplied
Après examen du code :
def insert(array): connection = sqlite3.connect('images.db') cursor = connection.cursor() cnt = 0 while cnt != len(array): img = array[cnt] print(array[cnt]) cursor.execute('INSERT INTO images VALUES(?)', (img)) cnt += 1 connection.commit() connection.close()
Il devient clair que le problème réside dans la manière dont le paramètre de liaison est spécifié dans l'instruction curseur.execute :
cursor.execute('INSERT INTO images VALUES(?)', (img))
Pour résoudre l'erreur, une virgule est nécessaire pour créer un tuple :
cursor.execute('INSERT INTO images VALUES(?)', (img,))
Alternativement, un littéral de liste peut être utilisé :
cursor.execute('INSERT INTO images VALUES(?)', [img])
En vous assurant que le paramètre de liaison est correctement fourni sous forme de tuple ou de liste, le nombre correct de liaisons sera utilisé, résolvant l'erreur.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!