IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Python Discussion :

Requête paramétrée et wildcard en SQL [Python 2.X]


Sujet :

Python

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    237
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Novembre 2007
    Messages : 237
    Points : 99
    Points
    99
    Par défaut Requête paramétrée et wildcard en SQL
    Bonjour à tous,

    Je sollicite votre aide pour résoudre un problème lié à une requête paramétrée avec wildcard sql embarquée dans un script.

    Voici le script, je génère un date de type str puis je souhaite la passer en paramètre avec wildcard '%' dans mas requête pour ce faire j'ai suivi http://stackoverflow.com/questions/3...dcards-in-like

    mais ça fonctionne pas et je ne comprends pas pourquoi

    le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    start_date = datetime.datetime.now() - timedelta(days=day)
    day_str = start_date.strftime('%d/%m/%y')
    sql = ('SELECT Num, Horodatage, Total_active_power_moy FROM ' + table + ' WHERE Horodatage LIKE ?', (day_str+'%'))
    le message d'erreur
    ValueError: operation parameter must be str or unicode
    alors que ma variable day_str est bien de type str


    merci de votre aide

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Salut,

    Votre variable "sql" est un tuple.
    Vous ne montrez pas comment elle est passée à .execute (pour autant que ce soit cette instruction là qui remonte l'erreur).
    Et vous ne respectez pas la syntaxe de la discussion d'overflow.
    Quel est le sens d'un LIKE sur une date?
    A peu près ce jour là, c'est plutôt entre deux dates. Sinon est ce que c'est a peu près le même jour, ou la même semaine, la même année?

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Salut,

    Où est ta commande execute ?

    Je suppose qu'elle vient ensuite et qu'elle est comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    cursor.execute(sql)
    seulement sql n'est pas une chaîne de texte, tu as construit là un tuple.

    Si tu veux préparer ta commande avant de l'exécuter fais plutôt comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    sql = 'SELECT Num, Horodatage, Total_active_power_moy FROM ' + table + ' WHERE Horodatage LIKE ?'
    cursor.exécute(sql, (day_str+'%',))
    Si ma mémoire ne me trompe pas, l'argument doit être un tuple, d'où la virgule finale.

  4. #4
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2007
    Messages
    237
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Novembre 2007
    Messages : 237
    Points : 99
    Points
    99
    Par défaut
    waouh merci pour vos réponses, effectivement j'ai construit un tuple

    En suivant les instructions de VinsS j'ai modifié mon code qui maintenant fonctionne.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
        data = []
        for day in range(DAYS):
            start_date = datetime.datetime.now() - timedelta(days=day)
            day_str = start_date.strftime('%d/%m/%y')
            sql = ('SELECT Num, Horodatage, Total_active_power_moy FROM ' + table +
                   ' WHERE Horodatage LIKE ?')
            print sql
            con = sqlite3.connect(db_path)
            with con:
                cur = con.cursor()
                cur.execute(sql, (day_str+'%',))
                rows = cur.fetchall()
                data.extend(rows)
    il mérite encore d'être optimisé...


    Merci de votre aide

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Oracle] Requête paramétrée
    Par zchallal dans le forum Langage SQL
    Réponses: 4
    Dernier message: 08/05/2006, 00h00
  2. Réponses: 5
    Dernier message: 04/05/2006, 21h02
  3. Exporter une requête paramétrée
    Par Al soltani dans le forum Access
    Réponses: 2
    Dernier message: 20/04/2006, 14h15
  4. Requete parametree
    Par Mihalis dans le forum Bases de données
    Réponses: 1
    Dernier message: 07/04/2006, 10h11
  5. Requetes parametrees
    Par Pierren dans le forum Access
    Réponses: 6
    Dernier message: 29/01/2006, 16h52

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo