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
Libérer: 2024-12-05 01:15:10
original
1027 Les gens l'ont consulté

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
Copier après la connexion

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()
Copier après la connexion

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))
Copier après la connexion

Pour résoudre l'erreur, une virgule est nécessaire pour créer un tuple :

cursor.execute('INSERT INTO images VALUES(?)', (img,))
Copier après la connexion

Alternativement, un littéral de liste peut être utilisé :

cursor.execute('INSERT INTO images VALUES(?)', [img])
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal