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 :

Récupération de la derniére ligne de mes enregistrements


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    informatique
    Inscrit en
    Avril 2012
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : informatique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 89
    Par défaut Récupération de la derniére ligne de mes enregistrements
    Bonjour je cherche à récupérer l'Identifient de mon dernier enregistrement dans mon datagridview dans un label.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
     Dim ligne As String  ' la position que je veu récupérer
            Dim table As New RTDS.Nom_TableDataTable   'RTDS le nom de mon dataset
    ligne = table.Rows.Count - 1    'Pour se placer sur la derniére ligne
     If ligne > table.Rows.Count - 1 Then
                    Me.label1.Text = table.Rows(ligne).Item("Id")
                End If
    mais ca ne marche pas, label ne prend pas l'ID de la dernière valeur mais prend la valeur initiale.
    Pourriez vous m'aider ?

    Merci.

  2. #2
    Membre Expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 793
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ligne = table.Rows.Count - 1    'Pour se placer sur la derniére ligne
     If ligne > table.Rows.Count - 1 Then
    Comment "ligne" pourrait être supérieur à la valeur qu'on vient de lui attribuer ?

  3. #3
    Membre confirmé
    Homme Profil pro
    informatique
    Inscrit en
    Avril 2012
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : informatique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 89
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Me.label1.Text = table.Rows(ligne).Item("Id")
    si j'ai fais une erreur la bas c'est que j'ai vu mais l'objectif c'est de récupérer la valeur dans label1

  4. #4
    Membre confirmé
    Homme Profil pro
    informatique
    Inscrit en
    Avril 2012
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : informatique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 89
    Par défaut
    j'ai testé avec ca
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
            Dim ligne As String = MonDataGridView.Rows.Count - 1
     
    label1.Text = MonDataGridView.Rows(ligne).Cells(0).Value.ToString
    ca me génére une erreur d'instance sur la ligne label1.Text = MonDataGridView.Rows(ligne).Cells(0).Value.ToString

  5. #5
    Membre Expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 793
    Par défaut
    parce que ligne doit être égal à -1 et on ne peut pas avoir la valeur de la ligne -1 d'un datagridview ...
    Il faudrait utiliser le mode pas à pas et chercher un peu !

  6. #6
    Membre Expert
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    700
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 700
    Par défaut
    Bonsoir,
    Déjà, dans l'onglet "Projet" de ton IDE, puis "Propriété de ton projet", coche "Option Strict" sur On.
    Tu verras ensuite une erreur sur cette déclaration
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim ligne As String = MonDataGridView.Rows.Count - 1
    Tu déclares un String pour récupérer un Integer ...


    Ensuite DataGridView possède une propriété AllowUserToAddRows permettant ou non d'ajouter une ligne vierge de saisie en fin.
    Dans ton cas je pense que c'est autorisé et tu cibles cette ligne qui provoque l'erreur que tu mentionnes car elle n'est pas encore instanciée :
    La référence d'objet n'est pas définie à une instance d'un objet.
    Donc il faut traiter cette dernière ligne (-1) pour connaitre son statut et si c'est une NewRow, il faut donc remonter à la ligne précédente (-2).
    Genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
            Dim numLigne As Integer = DataGridView1.RowCount - 1
     
            If DataGridView1.Rows(numLigne).IsNewRow Then
                numLigne = DataGridView1.RowCount - 2
            End If
            Label1.Text = DataGridView1.Rows(numLigne).Cells(0).Value.ToString

Discussions similaires

  1. [XL-2010] Plantage sur la récupération de la dernière ligne
    Par juju05 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 03/10/2014, 09h24
  2. [Débutant] Obtenir la dernière ligne de mon enregistrement
    Par solaar dans le forum Linq
    Réponses: 4
    Dernier message: 13/11/2013, 10h12
  3. Récupération valeurs de la dernire ligne
    Par macsigarev dans le forum Développement de jobs
    Réponses: 12
    Dernier message: 09/05/2012, 16h01
  4. Réponses: 1
    Dernier message: 13/06/2008, 20h14
  5. Réponses: 6
    Dernier message: 03/12/2007, 14h13

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