begin process at 2012 05 27 07:20:58
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

SQL

 > QUAND METTRE UNE CLAUSE WHERE?

QUAND METTRE UNE CLAUSE WHERE?


 Information sur la source

Note :
6 / 10 - par 1 personne
6,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :SQL Niveau :Débutant Date de création :07/07/2002 Date de mise à jour :07/07/2002 04:24:18 Vu :5 940

Auteur : Black_Pit

Ecrire un message privé
Site perso
Commentaire sur cette source (0)
Ajouter un commentaire et/ou une note

 Description

Il peut arriver qu'on laisse l'utilisateur choisir le ou les champs sur lesquels il veut faire une recherche (ou même aucun champ!!!).  Voici un petit bout de code afin de déterminer si vous avez besoin de mettre la clause WHERE ou la clause AND.  Supposez que la page ASP reçoit 3 champs par la méthode GET.

Source

  • Dim strSQL 'la requète SQL
  • Dim blnWhereAdded 'True (1) si on a déjà ajouté la clause WHERE
  • Dim strField1 'la valeur du 1er champ... De type string
  • Dim intField2 'la valeur du 2ième champ... De type integer
  • Dim strField3 'la valeur du 3ième champ... De type string
  • '
  • ' Définissez votre connexion et initialisez les trois variables strFieldx
  • '
  • blnWhereAdded = False
  • strSql = "SELECT * FROM Ma_Table"
  • If strField1 <> "" Then
  • If Not blnWhereAdded Then
  • strSQL = strSQL & " WHERE "
  • blnWhereAdded = True
  • Else
  • strSQL = strSQL & " AND "
  • End If
  • strSQL = strSQL & "Champ1 LIKE '%" & strField1 &"%'"
  • End If
  • If intField2 <> "" Then
  • If Not blnWhereAdded Then
  • strSQL = strSQL & " WHERE "
  • blnWhereAdded = True
  • Else
  • strSQL = strSQL & " AND "
  • End If
  • strSQL = strSQL & "Champ2 = " & intField2
  • End If
  • If strField3 <> "" Then
  • If Not blnWhereAdded Then
  • strSQL = strSQL & " WHERE "
  • blnWhereAdded = True
  • Else
  • strSQL = strSQL & " AND "
  • End If
  • strSQL = strSQL & "Champ3 LIKE '%" & strField3 &"%'"
  • End If
  • '
  • 'Exécutez la requête strSQL puis affichez les résultats
  • '
Dim strSQL                'la requète SQL
Dim blnWhereAdded   'True (1) si on a déjà ajouté la clause WHERE
Dim strField1              'la valeur du 1er champ... De type string
Dim intField2              'la valeur du 2ième champ... De type integer
Dim strField3              'la valeur du 3ième champ... De type string

'
' Définissez votre connexion et initialisez les trois variables strFieldx
'
blnWhereAdded = False
strSql = "SELECT * FROM Ma_Table"

If strField1 <> "" Then
  If Not blnWhereAdded Then
    strSQL = strSQL & " WHERE "
    blnWhereAdded = True
  Else
    strSQL = strSQL & " AND "
  End If
  strSQL = strSQL & "Champ1 LIKE '%" & strField1 &"%'"
End If

If intField2 <> "" Then
  If Not blnWhereAdded Then
    strSQL = strSQL & " WHERE "
    blnWhereAdded = True
  Else
    strSQL = strSQL & " AND "
  End If
  strSQL = strSQL & "Champ2 = " & intField2
End If  

If strField3 <> "" Then
  If Not blnWhereAdded Then
    strSQL = strSQL & " WHERE "
    blnWhereAdded = True
  Else
    strSQL = strSQL & " AND "
  End If
  strSQL = strSQL & "Champ3 LIKE '%" & strField3 &"%'"
End If

'
'Exécutez la requête strSQL puis affichez les résultats
' 

 Conclusion

Avec ce code, si l'utilisateur fait une recherche sur aucun champ, la variable strSQL aura la valeur suivante: "SELECT * FROM Ma_Table"

Si l'utilisateur fait une recherche sur le 1er et 2ième champ:
"SELECT * FROM Ma_Table WHERE Champ1 LIKE '%Valeur_Entrée%' AND Champ2 = Valeur_Entrée"

Si l'utilisateur fait une recherche uniquement sur le 3ième champ:
"SELECT * FROM Ma_Table WHERE Champ3 LIKE '%Valeur_Entrée%'"

Amusez-vous à trouver les autres combinaisons si vous n'avez toujours pas compris!!!

Vous pouvez faire le même procédé si vous demandez à l'utilisateur dans quelle ordre il veut afficher les résultats.


 Sources du même auteur

Source avec Zip Source avec une capture AFFICHAGE PAR PAGE DU RÉSULTAT D'UNE REQUÊTE

 Sources de la même categorie

CHANGEMENT DE MOT DE PASSE ASP-ACCESS par semetic
Source .NET (Dotnet) CONNEXION SQL SERVEUR + LISTBOX par zeb13
SQL - QUELQUES REQUETTES SQL INTÉRESSANTES par fabrice69
PETITES FONCTIONS ENTRE AMIS par LleWellA
AUTOMATISATION DES CONNECTION ET RECORDSET par pi0up51

Commentaires et avis

Aucun commentaire pour le moment.

 Ajouter un commentaire




Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,515 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales