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 :

Extraire les données d'un dataset


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    661
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juin 2006
    Messages : 661
    Par défaut Extraire les données d'un dataset
    Bonjour j'ai besoin d'utiliser un dataset que j'ai déjà remplis mais je n'arrive pas a extraire les données de celui-ci.

    Je sais qu'il y a la notion de DataRow: chaque DataTable inclut plusieurs objets DataRow qui contiennent les données de la source dans un enregistrement ou une présentation de type enregistrement;
    DataColumn: plusieurs objets DataColumn définissent les colonnes de chaque DataRow.

    J'ai essayé ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox(dts.Tables.Item(1).Rows(0).ToString)
    Mais ça me renvois système.data.datarow
    J'ai aussi essayé çà

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
            MsgBox (dts.Tables["test"].Rows[0][0])
            MsgBox (dts.Tables[0].Rows[0]["CustomerID"])
    Mais ça me renvois identificateur attendu.

    Merci d'avance

  2. #2
    Membre éclairé Avatar de sihammaster
    Webmaster
    Inscrit en
    Mai 2009
    Messages
    256
    Détails du profil
    Informations professionnelles :
    Activité : Webmaster
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2009
    Messages : 256
    Par défaut
    Bonjour,
    essayer ca:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    dim dt as new DataTable()
    dt=dts.Table("Ta Table")
    Me.TextBox1.Text = dt.Rows(0)("nom")

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    661
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juin 2006
    Messages : 661
    Par défaut
    Ok super, donc je dois passé par un datatable pour extraire les données du dataset

    Merci

  4. #4
    Expert confirmé Avatar de Graffito
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5 993
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 993
    Par défaut
    Et aussi penser à la fonction bien pratique : DataTable.Select() qui renvoie une liste de DataRows filtrée.

  5. #5
    Membre Expert Avatar de hunteshiva
    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Février 2010
    Messages
    1 069
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2010
    Messages : 1 069
    Par défaut
    pas besoin de passer par un datable pour extraire des éléments de ton DataSet

    les erreurs générées sont normales a mes yeux
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    MsgBox (dts.Tables["test"].Rows[0][0])
            MsgBox (dts.Tables[0].Rows[0]["CustomerID"])
    tu utilise des crochets "[]" ...
    c'est pas des parenthèses plutôt ??
    *j'ais jamais essayé comme sa*



    je te montre une partie du programme que je suis en train de dévelloper qui fonctionne très bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ObjetDataTableTblDim = ObjetDataSetTblDim.Tables("tblDimensions")
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    'Enregistrement des valeurs dans des variables
                dtNumCoupure = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("NumCoupure").ToString)
                dtNomCoupure = ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("NomCoupure").ToString
                dtCodeProduit = ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("CodeProduit").ToString
                dtLargeurPalette = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("LargeurPalette").ToString)
                dtLongueurPalette = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("LongueurPalette").ToString)
                dtHauteurPalette = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("HauteurPalette").ToString)
                dtLargeurBoite = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("LargeurBoite").ToString)
                dtLongueurBoite = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("LongueurBoite").ToString)
                dtHauteurBoite = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("HauteurBoite").ToString)
    c'est asse lourd j'avoue


    mais en résumé la méthode est simple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    maVariable = monDataSet.Tables(NomTable).Rows(indexLigne).Item(indexColonne).ToString
    'avec NomTable = string et les index = Integer
     
    'ou
    maVariable = monDataSet.Tables(NomTable).Rows(indexLigne).Item(NomColonne).ToString
    'avec l'index = integer et NomTable, NomColonne = String
    je t'ais mis sa un peut vite alors il y a p-e des erreus mais je pense pas



    Bonne continuation

  6. #6
    Membre Expert Avatar de hunteshiva
    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Février 2010
    Messages
    1 069
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2010
    Messages : 1 069
    Par défaut
    je te rajout un bout de code qui pourra te servir on se sais jamais
    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
     'Ouverture de la base a l'aide d'une interface "OpenFileDIalog" de VB.net
            Dim dialogOpen As New OpenFileDialog
            With dialogOpen
                .InitialDirectory = Application.StartupPath & "\" 'répertoire sur lequel s'ouvrira la boite
                .Title = "Choisir une fichier" 'titre de la barre
                .Filter = "Base de données(*.mdb)|*.mdb" 'filtre, seules les fichiers .mdb apparaîtront
                .ShowDialog() ' on ouvre la boite de dialogue enfin
     
            End With
     
     
            '################################################################
            '########### Initialisation des chaînes de connexion ############
            '################################################################
            'Initialisation de la chaîne de paramètres pour la connexion
            strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" & "Data Source=" & dialogOpen.FileName & ";"
    j'utilise les base de données Access mais tu a juste a adapter le code si sa t'interesse
    tu change le filtre et tu a une fenétre propre pour ouvrir ta base et récuperer le chemin de ta base

  7. #7
    Modérateur
    Avatar de Sankasssss
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2006
    Messages
    1 842
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 842
    Par défaut
    Citation Envoyé par hunteshiva Voir le message
    je te montre une partie du programme que je suis en train de dévelloper qui fonctionne très bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ObjetDataTableTblDim = ObjetDataSetTblDim.Tables("tblDimensions")
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    'Enregistrement des valeurs dans des variables
                dtNumCoupure = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("NumCoupure").ToString)
                dtNomCoupure = ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("NomCoupure").ToString
                dtCodeProduit = ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("CodeProduit").ToString
                dtLargeurPalette = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("LargeurPalette").ToString)
                dtLongueurPalette = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("LongueurPalette").ToString)
                dtHauteurPalette = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("HauteurPalette").ToString)
                dtLargeurBoite = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("LargeurBoite").ToString)
                dtLongueurBoite = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("LongueurBoite").ToString)
                dtHauteurBoite = CInt(ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex)).Item("HauteurBoite").ToString)
    c'est asse lourd j'avoue
    C'est surtout pas facile a lire

    Utilise au minimum un with :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    'Enregistrement des valeurs dans des variables
            With ObjetDataTableTblDim.Rows(indexCmbxCoupure(cmbxNomCoupure.SelectedIndex))
                dtNumCoupure = CInt(.Item("NumCoupure").ToString)
                dtNomCoupure = .Item("NomCoupure").ToString
                dtCodeProduit = .Item("CodeProduit").ToString
                dtLargeurPalette = .Item("LargeurPalette").ToString)
                dtLongueurPalette = CInt(.Item("LongueurPalette").ToString)
                dtHauteurPalette = CInt(.Item("HauteurPalette").ToString)
                dtLargeurBoite = CInt(.Item("LargeurBoite").ToString)
                dtLongueurBoite = CInt(.Item("LongueurBoite").ToString)
                dtHauteurBoite = CInt(.Item("HauteurBoite").ToString)
          End With
    C'est quand même mieux, et en plus c'est plus performant : With...End With, instruction (Visual Basic)
    With...End With permet d'appliquer une série d'instructions à l'objet spécifié, sans désigner à chaque fois le nom de l'objet. Si le chemin d'accès de qualification à l'objet est long, l'utilisation de With...End With peut améliorer vos performances. Un bloc With permet également d'éviter les frappes répétées du chemin d'accès de qualification et les erreurs de frappe d'un de ses éléments.

    Par exemple, pour modifier plusieurs propriétés d'un seul objet, placez les instructions d'assignation de propriétés dans With...End With ; vous ne faites ainsi référence qu'une seule fois à l'objet, au lieu de le faire à chaque assignation de propriété.

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

Discussions similaires

  1. Extraire les données ID3 d'une musique
    Par FluidBlow dans le forum C++Builder
    Réponses: 2
    Dernier message: 04/10/2006, 20h04
  2. [C# 2005]recuperer les données d'un dataset
    Par skud dans le forum Windows Forms
    Réponses: 2
    Dernier message: 18/09/2006, 17h55
  3. Réponses: 12
    Dernier message: 18/07/2006, 19h51
  4. [VB.NET] Transférer les données d'un dataset vers excel ??
    Par beegees dans le forum Windows Forms
    Réponses: 3
    Dernier message: 11/06/2006, 18h59
  5. Pour extraire les données d'un fichier texte
    Par Floch dans le forum Access
    Réponses: 2
    Dernier message: 02/05/2006, 15h01

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