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 :

DataReader et clé primaire


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Janvier 2006
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 33
    Par défaut DataReader et clé primaire
    Bonjour,

    j'utilise un objet datareader pour acceder à un champ d'une table et j'aimerais pouvoir récupérer la clé primaire correspondant à la valeur que je lie lorsque je parcour mon champ. Pour l'instant j'incrémente une compteur i mais la lecture est parfois aléatoire et mon i ne correspond plus à la clé primaire du coup :

    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
     
    Imports System.Data
    Imports System.Data.OleDb
     
    Friend Class FetchBdd
     
        Protected Table As String
        Protected Champ As String
        Protected ParamConnexion As String = "Provider=Microsoft.Jet.OLEDB.4.0;Data source=" & _
            My.Settings.DataSourceBdd '"LaboEMCSS_v2.0.mdb" 
     
     
        Public Function getResults(ByVal Table As String, ByVal Champ As String) As String()
            Dim i As Integer
            Dim text As String
            Dim results(30) As String
            Dim MyConnexion As OleDbConnection = New OleDbConnection(ParamConnexion)
     
            Dim Mycommand As OleDbCommand = MyConnexion.CreateCommand()
            Dim ReqPrepared As String = "SELECT " & Champ & " FROM " & Table
            Mycommand.CommandText = ReqPrepared
            MyConnexion.Open()
            Try
                Dim myReader As OleDbDataReader = Mycommand.ExecuteReader()
                i = 0
     
                Try
                    Do While myReader.Read()
                        Try
                            'C'est ic que je veux recupérer la clé primaire dans la variable i par exemple :
                            results(i) = myReader.GetString(0).ToString
                        Catch ex As Exception
                            'Donnée vide
                            results(i) = ""
                        End Try
                        i = i + 1
                    Loop
     
                Catch ex As Exception
     
                End Try
                myReader.Close()
            Catch ex As Exception
                MsgBox("Requete incorrect")
            End Try
            MyConnexion.Close()
            Return results
        End Function
    End Class
    en gros j'aimerais pouvoir faire ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    i = myReader.getRow(0)
    results(i) = myReader.GetString(0).ToString
    y' a t il une solution avec le datareader ?

    Merci d'avance pour votre aide !

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    Bah il faut ajouter la clé primaire dans la requête... Par exemple si la clé primaire s'appelle "Id", ça donne ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim ReqPrepared As String = "SELECT Id, " & Champ & " FROM " & Table

  3. #3
    Membre averti
    Inscrit en
    Janvier 2006
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 33
    Par défaut
    Merci pour ta réponse,

    Ca ne fonctionne pas au niveau de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     results(i) = myReader.GetString(0).ToString
    donc je pense que ma requete passe bien mais la méthode pour retourner le resultat semble incorrect

    Sous quelle forme vais je récuperer mon resultat du coup?

  4. #4
    Membre averti
    Inscrit en
    Janvier 2006
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 33
    Par défaut
    J'ai trouvé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    results(myReader.GetInt32(0)) = myReader.GetString(1).ToString
    myReader.GetInt32(0) contient la clé primaire.

    Par contrej'aurais pensé que la lecture du datareader retourne un array...

  5. #5
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 200
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 200
    Par défaut
    si tu veux un array tu peux utiliser lereader.getvalues()
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  6. #6
    Membre averti
    Inscrit en
    Janvier 2006
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 33
    Par défaut
    Merci pour vos réponses.

    J'avais regarder le getvalues avec l'exemple dans la msdn mais impossible de récuprer qqchose !

    Je clos.

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

Discussions similaires

  1. Import data d'Excel ds 2 table lié par clé primaire
    Par lord_paco dans le forum MS SQL Server
    Réponses: 11
    Dernier message: 10/05/2005, 09h31
  2. clé primaire composée de 2 clés étrangères
    Par Tigresse dans le forum Installation
    Réponses: 5
    Dernier message: 28/07/2003, 14h38
  3. clé primaire aléatoire
    Par peuh dans le forum PostgreSQL
    Réponses: 8
    Dernier message: 23/06/2003, 20h51
  4. Procédure stocké:Insert et renvoie de la clé primair
    Par caramel dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 17/04/2003, 09h34
  5. Problème pour récupérer la clé primaire
    Par caramel dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 11/04/2003, 13h57

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