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

Requêtes et SQL. Discussion :

SELECT TOP SELECT, est-ce possible ?


Sujet :

Requêtes et SQL.

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2004
    Messages : 2
    Points : 2
    Points
    2
    Par défaut SELECT TOP SELECT, est-ce possible ?
    Bonjour à tous !

    Sous Access 2003, je dois modifier une requête qui pour l'instant est du style :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT TOP 95 PERCENT champ1, champ2 FROM matable WHERE condition

    Cette requête renvoi bien le résultat que je souhaite lorsque 95% est supérieur strict à 1. Par exemple, 95% de 47 = 44,65. La requête me renvoi donc 45 lignes. Ce que je souhaite.

    Par contre, 95% de 9 = 8,55. La requête me renvoi donc 9 lignes.
    Mais dans ce cas, je voudrais une exception, je voudrais que la requête ne me renvoi que 8 lignes et qu'elle laisse une ligne de côté.

    J'ai donc essayé plusieurs méthodes.
    • faire un SELECT TOP [parametre] champ FROM .... ou [parametre] était calculé du côté VBA
    • SELECT TOP SELECT IIf(count(*)*95/100 < 1, si vrai, si faux) mais ceci est impossible
    • En passant par une table intermédiaire qui me donne le résultat de 95% et ensuite faire appel à ce résultat dans un SELECT TOP SELECT


    Mais aucune de ces solutions ne fonctionne. le SELECT TOP SELECT ne fonctionne pas sous Access à ce que je constate (je ne suis pas du tout un expert Access). Est-ce vraiment le cas ou est-ce moi qui ne sait pas l'utiliser ?
    Il est impossible de passer un parametre après le TOP ? On ne peut passer des paramètres que dans la clause WHERE ?

    Est-ce que vous avez une autre petite idée de méthode que je pourrais utiliser pour gérer mon exception ?

    Je vous remercie d'avance pour l'aide que vous pourrez me fournir.

  2. #2
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 768
    Points
    7 768
    Par défaut
    Bonsoir,

    une solution consisterait à créer la requête en vba.

    Exemple basé sur la table [Détails Commandes] de la base exemples COMPTOIR.MDB comme point de départ:
    Code vba : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    Dim db As DAO.Database, qd As DAO.QueryDef
    Dim strQueryName As String, strSQL As String, strWHERE  As String
    Dim NbLig As Long, NbLig2 As Long
     
    strQueryName = "MaRequete"
    Set db = CurrentDb
    On Error Resume Next
    Set qd = db.QueryDefs(strQueryName)
    On Error GoTo 0
     
    ' Si la requête n'existe pas, on la crée
    If qd Is Nothing Then
       Set qd = db.CreateQueryDef(strQueryName)
    End If
     
    ' Critère de sélection
    strWHERE = "[Quantité]>110"
     
    ' Compte des lignes
    NbLig = DCount("*", "Détails commandes", strWHERE)
    ' 95% des lignes
    NbLig2 = 0.95 * NbLig
     
    ' Ajustement
    If NbLig2 = NbLig Then NbLig2 = NbLig2 - 1
     
    ' Génération du SQL
    strSQL = "SELECT TOP " & CStr(NbLig2) & " * FROM [Détails commandes]" & vbCrLf & _
             "WHERE " & strWHERE
     
    ' On met le SQL dans la requête
    qd.SQL = strSQL
    db.Close
     
    DoCmd.OpenQuery strQueryName
    A+

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2004
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Merci beaucoup !

    J'ai pu résoudre mon problème grâce à ta solution !!!

    Un grand merci !

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

Discussions similaires

  1. select in (select in (select in etc.))
    Par Christophe P. dans le forum Langage SQL
    Réponses: 4
    Dernier message: 28/01/2015, 11h34
  2. Réponses: 6
    Dernier message: 20/11/2007, 11h14
  3. Réponses: 3
    Dernier message: 06/04/2007, 10h09
  4. Réponses: 7
    Dernier message: 09/05/2006, 11h30
  5. Select case est-il possible dans ce cas ?
    Par rangernoir dans le forum Access
    Réponses: 10
    Dernier message: 30/09/2005, 16h06

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