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 :

Comment faire en sql ?


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 16
    Par défaut Comment faire en sql ?
    Bonjour,
    je souhaite faire une recherche.
    mon fichier hf qui contient les données

    Rubrique
    1 2 3 4
    Données a a b a
    b c a b
    a c a b
    c b b c
    a a c a
    b c c b
    c c a b
    8 lignes d'enregistrement

    Mon critere de recherche est 'b c a b' et doit me retourné tout les enregistrements qui contiennent de 2 des 4 criteres

    à t'il une soluce en sql
    Merci d'avance

  2. #2
    Membre Expert Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Par défaut
    Salut !

    Parler de fichier est un peu bizarre quand on est en SQL, mais passons...

    Bon, tu imagines bien que tu pourrais t'amuser à liste toutes tes combinaisons possibles dans ton filtre WHERE, mais c'est pas beau.

    Je te propose ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT *
    FROM TaTable
    WHERE 
    CASE col1 WHEN 'b' THEN 1 ELSE 0 END +
    CASE col2 WHEN 'c' THEN 1 ELSE 0 END +
    CASE col3 WHEN 'a' THEN 1 ELSE 0 END +
    CASE col4 WHEN 'b' THEN 1 ELSE 0 END >= 2
    - Le principe est de compter simplement le nombre de critères égaux...
    - J'ai mis >=, tu peux bien sûr remplacer par = si tu veux exactement deux critères justes
    - J'ai pas repris ta nomenclature parce que j'ai pas envie d'appeler mes colonnes "1", "2", ...

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 16
    Par défaut
    Bonsoir,
    merci pour la réponse
    Avant tout j'ai omis de préciser que je suis sur windev et
    je vois qu'il y a des instructions case, when,then,else et end
    que je ne trouve pas dans le jeu d'instruction sql de windev.
    Y a t'il un équivalent de code sql pour windev ?

  4. #4
    Modérateur
    Avatar de Chtulus
    Homme Profil pro
    Ingénieur
    Inscrit en
    Avril 2008
    Messages
    3 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2008
    Messages : 3 094
    Par défaut
    Bonjour,

    IF ... THEN ... ELSE

    Je crois que ça passe en français aussi...

    « Je ne cherche pas à connaître les réponses, je cherche à comprendre les questions. »
    - Confucius -

    Les meilleurs cours, tutoriels et Docs sur les SGBD et le SQL
    Tous les cours Office
    Solutions d'Entreprise



  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 16
    Par défaut
    Bonjour,
    je ne saisie tjrs pas, sous windev en sql comment je peux utiliser les instructions if, then,else,end,... ?

    Ma requete avec passage de parametres :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    SELECT 
    Selection.M1 AS M1,    
    Selection.M2 AS M2,    
    Selection.M3 AS M3,    
    Selection.M4 AS M4    
    FROM Selection
    WHERE Selection.M1 = {paramE1}
    AND Selection.M2 = {paramE2}
    AND Selection.M3 = {paramE3}
    AND Selection.M4 = {paramE4}
    Mon fichier hyper file:

    1 2 3 4
    -------
    a a b a
    b c a b
    a c a b
    c b b c
    a a c a
    b c c b
    c c a b

    Dans ma requete, mes criteres sont d'égalités stricte
    et la requete que je cherche à faire doit faire une recherche à partir
    du critere 'b c a b' avec au minimum 2 criteres trouvés;
    En résultat :

    a c a b
    b c c b
    b c a b
    c c a b



  6. #6
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Pacmann vous a donné la réponse SQL un peu plus haut.

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

Discussions similaires

  1. Requete SQL : comment faire un cumul
    Par yannick069 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 09/04/2015, 13h21
  2. [SQL] Comment faire avec SQL pour que les visiteurs voient la même donnée
    Par syl2042 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 28/08/2007, 14h39
  3. [SQL] requetes inbriquées, comment faire celle ci??
    Par Devil666 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 20/05/2005, 15h44
  4. Requête SQL complexe. Comment faire ....
    Par BilTCD dans le forum Langage SQL
    Réponses: 4
    Dernier message: 05/11/2004, 16h18
  5. Réponses: 2
    Dernier message: 03/05/2004, 12h13

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