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

Langage SQL Discussion :

Condition dans un sql


Sujet :

Langage SQL

  1. #1
    Inactif  
    Homme Profil pro
    Lycéen
    Inscrit en
    Juin 2017
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Juin 2017
    Messages : 1
    Par défaut Condition dans un sql
    Bonjour, voila je recherche à mettre des conditions sur mon programme python dans le c.execute() voila un exemple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    import sqlite3
    conn = sqlite3.connect('TABLES.db')
    c = conn.cursor()
     
    def ET(et_type, t):
        """Etablissement en fonction du type"""
        c.execute(
        """SELECT nom FROM ETABLISSEMENT, REFERE
        WHERE idnomprime = ETABLISSEMENT.id
        CASE WHEN """ + str(t) + """ > 0 THEN arrondissement = """ + str(t) + """AND idtype = """ + str(et_type) +"""
            ELSE  idtype = """ + str(et_type) +"""
        END;"""
        )
        return c.fetchall()
    Forcé de constater que cela ne fonctionne pas, le principe y est. En fait si je trouve le moyen de mettre des conditions sur des variables venant de python dans mon sql pour qu'il ajoute ou non une requete ("AND..." dans le WHERE) je gagnerais énormément de temps sinon je devrais recopier quasiment les mêmes codes sql en fonction des conditions écrites dans le python
    (if...: c.ecute(...)
    elif c.execute(...) ...),
    or j'ai 8 variables, donc si je fais comme cela j'ai 8! = 40 000 codes sql à peine différent à réaliser!

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 640
    Billets dans le blog
    10
    Par défaut
    Vous pouvez ajouter un case dans un WHERE mais la syntaxe de votre requête est invalide

    Voici un exemple de syntaxe possible :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Select [. . .]
    Where Case
        when col1=:val1 and col2>:val2 then 1
        when col1 between :valA and :valB then 1
        when etc...
        end =1
      and coln = :valn

Discussions similaires

  1. Condition dans requête SQL selon la valeur d'un champs
    Par Arakasix dans le forum Langage SQL
    Réponses: 2
    Dernier message: 21/09/2011, 12h02
  2. conditions dans une requete sql
    Par beve dans le forum Langage SQL
    Réponses: 2
    Dernier message: 04/05/2007, 14h29
  3. [Requête/SQL]Conditions dans un champs calculé
    Par taisherg dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 17/04/2007, 15h55
  4. Condition dans une requete (pas en SQL)
    Par Luc01 dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 08/12/2006, 22h57
  5. SQL pure : Condition dans une table enfant...
    Par l_apotre dans le forum Requêtes
    Réponses: 7
    Dernier message: 27/11/2005, 18h55

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