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

VBA Access Discussion :

filtre serveur inefficace


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    272
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2008
    Messages : 272
    Par défaut filtre serveur inefficace
    Bonjour tout le monde,

    Je fais appel à vous pour un problème de filtre sur un formulaire. Je travail sur Access 2003 sp3 avec une base de données SQL Server 2005.

    J'aimerais tout simplement appliquer un filtre sur mon form en fonction d'une saisie utilisateur. Je m'explique :

    L'utilisateur saisi un code correspondant aux premiers chiffres d'un code article, par exemple 311. L'applic est alors sensée afficher tous les articles dont le code commence par 311.

    J'ai donc mis un événement sur "AfterUpdate" du champ de saisie du filtre. Voici le code qui devrait me filtrer mon form:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Private Sub Filtrer()
        Dim filtre As String
     
        filtre = ""
     
        If tx_filtre_article.Value <> "" Or Not IsNull(tx_filtre_article.Value) Then
            filtre = "prv_afart.art_cod LIKE '" & tx_filtre_article.Value & "%'"
        End If
     
        Me.ServerFilter = filtre
        Me.ServerFilterByForm = True
        Me.Requery
     
    End Sub
    Or il ne se passe rien du tout, mon formulaire n'est pas filtrer! Par contre, si j'écris : prv_afart.art_cod LIKE '311%' dans la propriété Filtre Serveur du formulaire, oh miracle ce dernier est filtré comme je le souhaite! Je n'y comprends plus rien!!

    Alors si une bonne âme pouvait me donner un petit coup de main....

    Voili bon appétit à tous

    Julius

  2. #2
    Membre confirmé
    Avatar de antoinev2
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    177
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 177
    Par défaut
    Bonjour,

    Je ne connais pas sql server, mais sur une base de données sous Access 2003, il faut écrire, après avoir défini le filtre :

    En espérant que cette réponse soit utile,

    Cdt,

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    272
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2008
    Messages : 272
    Par défaut
    ... snif non malheureusement rien ne change!!!

    Impossible de filtrer ce maudit formulaire.. Heeelp

  4. #4
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 682
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 682
    Par défaut
    salut,
    en appliquant la proposition de antoinev2, tu peux nous montrer où en est ton code stp ?
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Migrer les applications VBA Access et VBA Excel vers la Power Platform
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Coffrets disponibles de mes ouvrages : https://www.editions-eni.fr/jean-philippe-andre
    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    272
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2008
    Messages : 272
    Par défaut
    Hello,

    alors voici ce que ça donne :

    Code : 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
    Private Sub Filtrer()
        Dim filtre As String
     
        filtre = ""
     
        If tx_filtre_article.Value <> "" Or Not IsNull(tx_filtre_article.Value) Then
            filtre = "prv_afart.art_cod LIKE '" & tx_filtre_article.Value & "%'"
        End If
        MsgBox filtre
        'Me.ServerFilter = filtre
        'Me.ServerFilterByForm = True
        Me.Filter = filtre
        Me.FilterOn = True
        Me.Refresh
        'Me.Requery
     
    End Sub
    Avec ce code j'obtiens l'erreur suivante : impossible d'appliquer un filtre sur un ou plusieurs champs spécifiés dans la propriété filtre.

    Les lignes en commentaires représente le code tel qu'il était avant que je ne modifie le code.

    J'y perds mon français! ça ne devrait tout de même pas être sorcier non?

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    272
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2008
    Messages : 272
    Par défaut
    AAAHHH Mais si je peux être bête!!!!! Encore une victime du lundi matin!!

    Je m'excuse mais mon erreur était en fait très très stupide!!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    filtre = "prv_afart.art_cod LIKE '" & tx_filtre_article.Value & "%'"
    Dans cette ligne j'attribue à la variable filtre la condition qui va filter mon formulaire... mais si j'orthographie mal mon champ, je ne vois pas comment le filtre peut fonctionner!!!

    En fait mon champ s'appelle et non Je m'excuse donc de vous avoir dérangé pour si peu! Me sens tout de même très hon sur le coup.

    Merci quand même et passez une bonne journée

    Julius

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 25/11/2010, 13h14
  2. [WS 2008] filtre sur serveur DHCP
    Par boboss123 dans le forum Windows Serveur
    Réponses: 0
    Dernier message: 23/12/2009, 08h53
  3. Réponses: 2
    Dernier message: 29/05/2007, 20h46
  4. Réponses: 2
    Dernier message: 01/05/2007, 12h51
  5. formulaires et les filtres serveur
    Par pedroIT dans le forum IHM
    Réponses: 4
    Dernier message: 12/12/2006, 10h37

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