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 :

Boucle For dans une requete SQL


Sujet :

Python

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2010
    Messages : 8
    Points : 8
    Points
    8
    Par défaut Boucle For dans une requete SQL
    Bonjour,

    J'ai besoin de boucler dans une requête sql mais j'ai un problème avec ma variable :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
        month=("january","february")
        # Computing the planning time for employee
        for m in month:
           cr.execute(
               "SELECT SUM(%s) as total "\
               "FROM hr_planning as plan "\
               "LEFT JOIN hr_planning_occupation as occ "\
               "ON plan.id=occ.planning_id "\
               "where plan.employee_id=%s and plan.name=%s ",
               (m, emp_id, year)
                )
    Comme erreur j'ai :
    ProgrammingError("function sum(unknown) is not unique\nLINE 1: SELECT SUM(E'January') as total FROM hr_planning as plan LEF...\n ^\nHINT: Could not choose a best candidate function. You might need to add explicit type casts.\n",)

    Je suppose que c'est lié au E' qu'il vient mettre devant... Problème d'encodage?
    Mais je ne trouve pas de doc sur internet concernant celui-ci, si vous avez un lien en même temps qui explique, je suis preneur!

    Merci d'avance pour votre aide!

  2. #2
    Membre expérimenté
    Profil pro
    Développeur en systèmes embarqués retraité
    Inscrit en
    Mars 2006
    Messages
    946
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2006
    Messages : 946
    Points : 1 351
    Points
    1 351
    Par défaut
    Salut,

    Comme ça, ça marche.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    import sys
    month=("january","february")
    # Computing the planning time for employee
    for m in month:
       sys.stdout.write("SELECT SUM(%s) as total FROM hr_planning as plan LEFT JOIN hr_planning_occupation as occ ON plan.id=occ.planning_id where plan.employee_id=%s and plan.name=%s\n"%(m, "ben-hur marcel", 1932))
    je pense que tu as eu un problème avec le '%' et le formatage, il aurait fallut un '%' avant la liste des paramètres de formatage (m, emp_id, year), tu as mis une virgule à la place.

    A+

    Pfeuh

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2010
    Messages : 8
    Points : 8
    Points
    8
    Par défaut
    Yes merci bcp, ca marche juste avec le %!

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

Discussions similaires

  1. [MySQL] Boucle FOR dans une requete Mysql
    Par skins dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 03/11/2011, 20h04
  2. [MySQL] Boucle for dans une requete avec jointure
    Par runcafre91 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 28/02/2010, 16h12
  3. [JDBC]Caractères spéciaux dans une requete SQL
    Par frizby dans le forum JDBC
    Réponses: 2
    Dernier message: 28/11/2005, 19h01
  4. symptome de la boucle infinie dans une requete
    Par ouam81 dans le forum Langage SQL
    Réponses: 8
    Dernier message: 27/05/2005, 13h10
  5. Mettre a jour les Parametres dans une requete SQL
    Par Tartar Ukid dans le forum C++Builder
    Réponses: 7
    Dernier message: 31/03/2004, 14h51

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