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

VB.NET Discussion :

Recherche dans DATABASE


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Octobre 2014
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes

    Informations forums :
    Inscription : Octobre 2014
    Messages : 19
    Par défaut Recherche dans DATABASE
    Bonsoir,

    Je suis débutant en VB et je développe sous VB 2010.
    J'ai créer un form avec une TextBox et un Bouton (pour faire simple pour l'instant). Ce form est directement relié à ma base de données Access via un databindindsource.
    J'ai écrit le code ci-dessous qui me permet de chercher tous les contacts qui ont un age précis. Mais mon but serait à terme d'afficher tous mes contacts dont l'age est supérieur ou égal à la valeur inscrite dans ma TextBox.
    Auriez vous des suggestions svp?

    Merci beaucoup.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Private Sub Button1_Click(sender As System.Object, e As System.EventArgs) Handles Button1.Click
            Dim age As String = ""
            Try
                If TextBox1.Text.Length > 0 Then
                    age = " Âge like '%" & TextBox1.Text & "%'"
                End If
     
                Me.ContactsIDBindingSource.Filter = age
            Catch ex As Exception
     
            End Try
     
        End Sub

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    210
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Juin 2010
    Messages : 210
    Par défaut
    Bonjour,

    J'ai écrit le code ci-dessous qui me permet de chercher tous les contacts qui ont un age précis.
    Pour information quand vous faites un LIKE % % , vous aller rechercher tous les enregistrements contenant la valeur entre les deux %.
    C'est à dire que Âge LIKE '%6%' va vous donner par exemple les personnes dont l'age est 16,26,60,69 ...

    dont l'age est supérieur ou égal à la valeur inscrite dans ma TextBox.
    remplacez le LIKE % % par >=

    Pour info, vos champs sont de quel type en base ?

    Pour finir, il aurait été bon de conclure la conversation sur le même sujet :
    http://www.developpez.net/forums/d14...ncee-database/

    A+

  3. #3
    Membre averti
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Octobre 2014
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes

    Informations forums :
    Inscription : Octobre 2014
    Messages : 19
    Par défaut
    Bonjour,

    Merci de votre réponse,

    Mes champs dans ma base de données Access sont sous forme Texte.
    Suite à votre suggestions j'ai changé mon code par celui-ci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Dim age As String = ""
            Try
                If TextBox1.Text.Length > 0 Then
                    age = " Âge '>=" & TextBox1.Text & "'"
                End If
     
                Me.ContactsIDBindingSource.Filter = age
            Catch ex As Exception
     MsgBox(ex.Message(), MsgBoxStyle.Critical, "Erreur")
            End Try
     
        End Sub
    Cependant j'ai le message d'erreur suivant lorsque je renseigne l'age dans ma texbox (30 par exemple) et que je clique sur mon bouton:
    "Erreur de synthaxe: Opérande manquante après l'opérateur ">= 30""



    J'ai donc changé mon code par:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    age = " Âge >=" & TextBox1.Text & ""
    Mais là encore j'ai le message d'erreur suivant:
    "Impossible d'effectuer une opération '>=' sur System.String et System.Int32."

    Auriez-vous une idées de l'erreur que j'ai commise???



    ps: oui merci, je pourrai conclure à mon ancien post dès que ce problème sera également réglé car les deux sont très proches (même si l'ancien est peut être un peu compliqué pour mon niveau de débutant...)

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    210
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Juin 2010
    Messages : 210
    Par défaut
    Le problème est que votre champ est de type TEXT en base de données et que vous essayez de le soumettre à une opération mathématique.

    D'ou l'erreur :
    "Impossible d'effectuer une opération '>=' sur System.String et System.Int32."
    je pense qu'il serait préférable de changer le type de votre champ Age dans la base de données.

    A+

  5. #5
    Membre averti
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Octobre 2014
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes

    Informations forums :
    Inscription : Octobre 2014
    Messages : 19
    Par défaut
    J'ai mis le champ de ma base sous forme Numérique mais j'ai toujours le même message d'erreur...

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    210
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Juin 2010
    Messages : 210
    Par défaut
    Avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    age = " Âge >= " & TextBox1.Text
    ?

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

Discussions similaires

  1. Macro de recherche dans une liste de mots à partir d'une DataBase
    Par Xorck dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 18/11/2014, 17h26
  2. recherche dans un projet
    Par FreshVic dans le forum Eclipse Java
    Réponses: 4
    Dernier message: 26/04/2004, 21h04
  3. [LG]rechercher dans un fichier texte
    Par BadFox dans le forum Langage
    Réponses: 11
    Dernier message: 01/12/2003, 16h57
  4. [BPW]Problème de recherche dans une boîte liste
    Par Alcatîz dans le forum Turbo Pascal
    Réponses: 14
    Dernier message: 05/07/2003, 16h10
  5. recherche dans un document xml via DOM
    Par ndoye_zaff dans le forum APIs
    Réponses: 5
    Dernier message: 11/06/2003, 15h44

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