Maison >développement back-end >Tutoriel Python >Pourquoi mon code SQLite3 génère-t-il une erreur « Liaisons incorrectes fournies » ?

Pourquoi mon code SQLite3 génère-t-il une erreur « Liaisons incorrectes fournies » ?

Barbara Streisand
Barbara Streisandoriginal
2024-12-05 01:15:101008parcourir

Why Does My SQLite3 Code Throw an

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn