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

MS SQL Server Discussion :

requete de recherche


Sujet :

MS SQL Server

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    132
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 132
    Points : 54
    Points
    54
    Par défaut requete de recherche
    bonjour,

    j'ai une requete sql (2000) qui me permet d'afficher les informations d'une societé en fonction du nom de la societé saisie dans un textbox.
    j'aimerai saisir par exemple juste une lettre puis cliquer sur rechercher. mais comme j'utilise un parametre ça ne passe pas.
    merci de votre aide.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CONTRATS_VALIDES.AFF_AFFAIRE2, CONTRATS_VALIDES.AFF_TIERS, CONTRATS_VALIDES.AFF_LIBREAFF1, CONTRATS_VALIDES.AFF_LIBREAFF3, CONTRATS_VALIDES.AFF_LIBREAFF5, CONTRATS_VALIDES.AFF_BOOLLIBRE2, CONTRATS_VALIDES.AFF_BOOLLIBRE3, TIERS_CEGID.T_AUXILIAIRE, TIERS_CEGID.T_TIERS, TIERS_CEGID.T_NATUREAUXI, TIERS_CEGID.T_LIBELLE, TIERS_CEGID.T_ADRESSE1, TIERS_CEGID.T_ADRESSE2, TIERS_CEGID.T_ADRESSE3, TIERS_CEGID.T_CODEPOSTAL, TIERS_CEGID.T_VILLE, TIERS_CEGID.T_PAYS, TIERS_CEGID.T_REPRESENTANT, TIERS_CEGID.Interlocuteur, TIERS_CEGID.C_RVA, TIERS_CEGID.C_TELEPHONE FROM CONTRATS_VALIDES INNER JOIN TIERS_CEGID ON CONTRATS_VALIDES.AFF_TIERS = TIERS_CEGID.T_TIERS  WHERE T_LIBELLE=@TextT_LIBELLE

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    72
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 72
    Points : 62
    Points
    62
    Par défaut
    WHERE T_LIBELLE like @TextT_LIBELLE + '%'
    @+

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    356
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Mai 2007
    Messages : 356
    Points : 406
    Points
    406
    Par défaut
    Au lieu d'utiliser un opérateur d'égalité, il faudrait que tu utilises un like dans une requête dynamique.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    DECLARE @query VARCHAR(8000)
    SET @query='SELECT CONTRATS_VALIDES.AFF_AFFAIRE2, CONTRATS_VALIDES.AFF_TIERS,
    CONTRATS_VALIDES.AFF_LIBREAFF1, CONTRATS_VALIDES.AFF_LIBREAFF3,
    CONTRATS_VALIDES.AFF_LIBREAFF5, CONTRATS_VALIDES.AFF_BOOLLIBRE2, CONTRATS_VALIDES.AFF_BOOLLIBRE3,
    TIERS_CEGID.T_AUXILIAIRE, TIERS_CEGID.T_TIERS, TIERS_CEGID.T_NATUREAUXI,
    TIERS_CEGID.T_LIBELLE, TIERS_CEGID.T_ADRESSE1, TIERS_CEGID.T_ADRESSE2, TIERS_CEGID.T_ADRESSE3,
    TIERS_CEGID.T_CODEPOSTAL, TIERS_CEGID.T_VILLE, 
    TIERS_CEGID.T_PAYS, TIERS_CEGID.T_REPRESENTANT, TIERS_CEGID.Interlocuteur, TIERS_CEGID.C_RVA,
    TIERS_CEGID.C_TELEPHONE
    FROM CONTRATS_VALIDES INNER JOIN TIERS_CEGID ON CONTRATS_VALIDES.AFF_TIERS = TIERS_CEGID.T_TIERS  
    WHERE T_LIBELLE like ''%'+@Text+'%''
    EXECUTE(@query)
    Je pense que ce type de solution correspond à ce que tu souhaites faire.

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    132
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 132
    Points : 54
    Points
    54
    Par défaut erreur sur texte
    bjr,
    j'ai un erreur la variable @Text doit être declarée et il manaque de guillements avant % , j'ai modifié mais je ne trouve pas.
    merci



    Citation Envoyé par Madinico
    Au lieu d'utiliser un opérateur d'égalité, il faudrait que tu utilises un like dans une requête dynamique.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    DECLARE @query VARCHAR(8000)
    SET @query='SELECT CONTRATS_VALIDES.AFF_AFFAIRE2, CONTRATS_VALIDES.AFF_TIERS,
    CONTRATS_VALIDES.AFF_LIBREAFF1, CONTRATS_VALIDES.AFF_LIBREAFF3,
    CONTRATS_VALIDES.AFF_LIBREAFF5, CONTRATS_VALIDES.AFF_BOOLLIBRE2, CONTRATS_VALIDES.AFF_BOOLLIBRE3,
    TIERS_CEGID.T_AUXILIAIRE, TIERS_CEGID.T_TIERS, TIERS_CEGID.T_NATUREAUXI,
    TIERS_CEGID.T_LIBELLE, TIERS_CEGID.T_ADRESSE1, TIERS_CEGID.T_ADRESSE2, TIERS_CEGID.T_ADRESSE3,
    TIERS_CEGID.T_CODEPOSTAL, TIERS_CEGID.T_VILLE, 
    TIERS_CEGID.T_PAYS, TIERS_CEGID.T_REPRESENTANT, TIERS_CEGID.Interlocuteur, TIERS_CEGID.C_RVA,
    TIERS_CEGID.C_TELEPHONE
    FROM CONTRATS_VALIDES INNER JOIN TIERS_CEGID ON CONTRATS_VALIDES.AFF_TIERS = TIERS_CEGID.T_TIERS  
    WHERE T_LIBELLE like ''%'+@Text+'%''
    EXECUTE(@query)
    Je pense que ce type de solution correspond à ce que tu souhaites faire.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    132
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 132
    Points : 54
    Points
    54
    Par défaut merci ça marche
    merci ça marche.



    Citation Envoyé par Bjuice2
    WHERE T_LIBELLE like @TextT_LIBELLE + '%'
    @+

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    356
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Mai 2007
    Messages : 356
    Points : 406
    Points
    406
    Par défaut
    Citation Envoyé par hermine
    bjr,
    j'ai un erreur la variable @Text doit être declarée et il manaque de guillements avant % , j'ai modifié mais je ne trouve pas.
    merci
    Correction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    DECLARE @query VARCHAR(8000)
    SET @query='SELECT CONTRATS_VALIDES.AFF_AFFAIRE2, CONTRATS_VALIDES.AFF_TIERS,
    CONTRATS_VALIDES.AFF_LIBREAFF1, CONTRATS_VALIDES.AFF_LIBREAFF3,
    CONTRATS_VALIDES.AFF_LIBREAFF5, CONTRATS_VALIDES.AFF_BOOLLIBRE2, CONTRATS_VALIDES.AFF_BOOLLIBRE3,
    TIERS_CEGID.T_AUXILIAIRE, TIERS_CEGID.T_TIERS, TIERS_CEGID.T_NATUREAUXI,
    TIERS_CEGID.T_LIBELLE, TIERS_CEGID.T_ADRESSE1, TIERS_CEGID.T_ADRESSE2, TIERS_CEGID.T_ADRESSE3,
    TIERS_CEGID.T_CODEPOSTAL, TIERS_CEGID.T_VILLE, 
    TIERS_CEGID.T_PAYS, TIERS_CEGID.T_REPRESENTANT, TIERS_CEGID.Interlocuteur, TIERS_CEGID.C_RVA,
    TIERS_CEGID.C_TELEPHONE
    FROM CONTRATS_VALIDES INNER JOIN TIERS_CEGID ON CONTRATS_VALIDES.AFF_TIERS = TIERS_CEGID.T_TIERS  
    WHERE T_LIBELLE like ''%'+@Text+'%'''
    EXECUTE(@query)
    Excuse moi j'avais oublié une simple côte.

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

Discussions similaires

  1. Requete et recherche
    Par jojo57 dans le forum Access
    Réponses: 6
    Dernier message: 17/05/2006, 14h54
  2. Requete pour rechercher tous les parents
    Par richard038 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 28/11/2005, 22h37
  3. Amélioration d'une requete de recherche
    Par sacrejohn dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 10/10/2005, 12h36
  4. optimisation d'une requete de recherche
    Par moog dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 06/04/2005, 17h58
  5. requete de recherche ? ou autre?
    Par Little-Freud dans le forum Access
    Réponses: 13
    Dernier message: 26/10/2004, 20h32

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