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 :

programmation vb.net en ado.net


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Août 2011
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vosges (Lorraine)

    Informations forums :
    Inscription : Août 2011
    Messages : 103
    Par défaut programmation vb.net en ado.net
    Bonjour, je me suis mis à vb.net il y a peu de temps et je réalise une insertion dans une base Access en Ado.net mais comme je pense (enfin j'espère il y a 2 façon).
    J'ai réalisé les 2 façon est celle-ci marche mais le concept reste très flou, si quelqu'un pourrais m'expliqué plus clairement merci d'avance.

    1ère façon :
    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
     
    'Enregistrement de l'utilisateur dans la base
        Public Sub Ajouter(ByVal NewUser As USER)
            'Try
            Dim cnx As OleDb.OleDbConnection = Nothing
            Dim cmd As OleDb.OleDbCommand
            cnx = Open_connexion()
            cmd = New OleDb.OleDbCommand
            cmd.CommandType = CommandType.Text
            Dim sql As String = "INSERT INTO UTILISATEUR (identifiant, mdp, question, reponse) VALUES (@login, @password, @question, @reponse)"
            cmd.CommandText = sql
            cmd.Parameters.AddWithValue("@login", NewUser.Login)
            cmd.Parameters.AddWithValue("@password", NewUser.Password)
            cmd.Parameters.AddWithValue("@question", NewUser.Question)
            cmd.Parameters.AddWithValue("@reponse", NewUser.Reponse)
            cmd.Connection = cnx
            cmd.ExecuteNonQuery()
            'Catch ex As Exception
            'Throw New Exception("Erreur ajout utilisateur" & Environment.NewLine & ex.Message)
            'End Try
        End Sub
    la 2ième façon (mode déconnecté, c'est flou pour moi)
    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
     
    Private AdaptUtilisateur As OleDbDataAdapter
        Private DtSet As New DataSet()
     
    Private Sub init()
            Dim cnx As OleDb.OleDbConnection = Nothing
            Dim sql As String = "select * from UTILISATEUR"
            cnx = Open_connexion()
            AdaptUtilisateur = New OleDb.OleDbDataAdapter(sql, cnx)
            AdaptUtilisateur.Fill(DtSet, "UTILISATEUR")
            cnx = Close_connexion()
        End Sub
     
    Public Sub autre_ajout(ByVal NewUser As USER)
            Dim cnx As OleDb.OleDbConnection = Nothing
            init()
            Dim newline As DataRow
            newline = DtSet.Tables("UTILISATEUR").NewRow
            newline(0) = NewUser.Login
            newline(1) = NewUser.Password
            newline(2) = NewUser.Question
            newline(3) = NewUser.Reponse
            DtSet.Tables("UTILISATEUR").Rows.Add(newline)
            cnx = Open_connexion()
            Dim cmdBuild As OleDb.OleDbCommandBuilder
            cmdBuild = New OleDb.OleDbCommandBuilder(AdaptUtilisateur)
            AdaptUtilisateur.InsertCommand = cmdBuild.GetInsertCommand()
            AdaptUtilisateur.Update(DtSet, "UTILISATEUR")
            cnx = Close_connexion()
        End Sub

  2. #2
    Membre émérite

    Homme Profil pro
    Inscrit en
    Mars 2012
    Messages
    691
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Israël

    Informations forums :
    Inscription : Mars 2012
    Messages : 691
    Par défaut
    Salut
    le mieux c'est de lire les cours
    http://plasserre.developpez.com/cour...bases-donnees1

  3. #3
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 202
    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 202
    Par défaut
    ta première méthode est la plus performante (mais de très peu je pense)
    la deuxième utilise des classes pour ceux qui ne savent pas ou ne veulent pas taper les requêtes

    ton code manque de try catch et de using/end using, donc lire le cours peut etre une bonne idée !

    aussi, ton code est long pour rien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Dim cmd As OleDb.OleDbCommand
    cmd = New OleDb.OleDbCommand
    =>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim cmd As New OleDb.OleDbCommand
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cmd.CommandType = CommandType.Text
    ce n'est pas la peine, c'est la valeur par défaut
    dim sql as string, ce n'est pas la peine non plus, la requête n'est pas super longue, tu peux mettre le string directement dans CommandText
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  4. #4
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Août 2011
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vosges (Lorraine)

    Informations forums :
    Inscription : Août 2011
    Messages : 103
    Par défaut
    shayw merci pour le lien cela ma permit de mieux comprendre chaque outil avec les définitions.

    Pol63 je suis d'accord avec toi sur le principe que le code est trop long mais cela viens juste du principe que j'ai suivi un tutoriel donc tous n'est pas simplifié. Pareil pour les try catch j'en avais pas mis pour l'instant le temps que je débeugais je les met seulement quand j'ai tester. Par contre using/end using je n'ai jamais utiliser je vais me documenter si t'as des liens c'est pas de refus.

    Merci à vous

  5. #5
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 202
    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 202
    Par défaut
    le lien pour using, c'est tu tapes using tu met ton curseur dessus et tu fais F1 ^^
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

Discussions similaires

  1. Réponses: 0
    Dernier message: 29/10/2009, 16h22
  2. [Vb.net 2005][ADO.net]Problème Update sur un champs calculé
    Par nirinasolomalala dans le forum Accès aux données
    Réponses: 2
    Dernier message: 13/03/2007, 09h14
  3. [VB.NET / ADO.NET] Mysql et .net
    Par sandytarit dans le forum Accès aux données
    Réponses: 3
    Dernier message: 07/12/2006, 17h05
  4. [debutante]apprendre vb.net et ado.net 2003
    Par dalhia dans le forum Windows Forms
    Réponses: 3
    Dernier message: 05/10/2006, 18h55
  5. [vb.net]problemme ADO.net update
    Par charaf dans le forum Windows Forms
    Réponses: 6
    Dernier message: 26/05/2006, 12h11

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