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

Visual Studio Discussion :

Charger une variable de Visual Studio 2010 vers une BD MySqlServer


Sujet :

Visual Studio

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Ingénieur en électrotéchnique
    Inscrit en
    Mai 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur en électrotéchnique
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2013
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Charger une variable de Visual Studio 2010 vers une BD MySqlServer
    Bonsoir à tous,
    je suis un débutant dans la programmation VB, j'ai créé une application qui fait des calcul et les stock dans une variable 'I0r', j'ai lié mon application avec une base de donnée que j'ai créée sur MySqlServer, et je veux stocker la variable 'I0r' dans la base de données MySql et j'ai mis le code suivant mais ça marche pas ça retourne une erreur de type de données:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Imports System.Data.SqlClient
    Public Class PremièreVu
        Dim cn As New SqlConnection("data source=NOUREDDINE-PC\EMI; initial catalog=Résultats; integrated security=true")
        Dim cm As New SqlCommand
    Private Sub Button1_Click_1(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
    cn.Open()
            cm.Connection = cn
            cm.CommandText = "insert into Réglages values ( '" & I0r & "')"
            cm.ExecuteNonQuery()
    End Sub
    "Résultats" est le nom de la DB
    " Réglages" est le nom de la table ou je veux stocker elle contient une seule colonne de type real
    et la vriabale I0r est de type Double.
    Je vous prie me répondre car je suis vraiment bloqué, et merci

  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 : 42
    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
    Points : 39 749
    Points
    39 749
    Par défaut
    J'ai l'impression que tu mélanges un peu MySQL et SQL Server... et "MySQLServer", ça n'existe pas

    D'après ton code, c'est une base SQL Server que tu utilises, pas MySQL.

    Citation Envoyé par dijas Voir le message
    " Réglages" est le nom de la table ou je veux stocker elle contient une seule colonne de type real
    et la vriabale I0r est de type Double.
    Si la variable vaut 15 par exemple, ta requête ressemble à ça :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into Réglages values ('15')

    Donc en fait tu essaies d'insérer une chaine de caractères ('15') dans une colonne de type real ; ces types ne sont pas compatibles, il faut insérer une valeur numérique, pas une chaine.

    Il faut donc enlever les apostrophes :
    Code VB.NET : Sélectionner tout - Visualiser dans une fenêtre à part
    cm.CommandText = "insert into Réglages values (" & I0r & ")"

    Cela dit, ça ne règle pas complètement le problème... Quand la valeur est entière, tout va bien, mais si elle a une partie décimale (par exemple 1.5), ça ne va sans doute plus marcher (du moins si ton système est en français). En effet, pour intégrer la variable I0r dans la requête, VB.NET appelle implicitement I0r.ToString(), qui ne donne pas le même résultat selon la langue... En anglais, ça donnerait cette requête, qui est correcte :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into Réglages values (1.5)
    Mais en français, le séparateur décimal est la virgule, pas le point ! Ca donne donc la requête suivante :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into Réglages values (1,5)
    Et là ça ne marche plus, car en SQL, la virgule sert à séparer les valeurs, et non à séparer la partie entière de la partie décimale...

    Bref, pour faire les choses proprement, il faut utiliser une requête paramétrée, qui évite d'avoir à se poser ce genre de questions :

    Code VB.NET : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
            cm.Connection = cn
            cm.CommandText = "insert into Réglages values (@value)"
            cm.Parameters.AddWithValue("value", I0r)
            cm.ExecuteNonQuery()

    Au fait, encore une petite chose que tu devrais changer : quand tu fais un INSERT, il faut toujours préciser les colonnes dans lesquelles tu insères. Sinon, le jour où tu ajoutes des colonnes dans la table, ton code ne fonctionne plus... La forme correcte est donc :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into Réglages(NomColonne) values (@value)

    (en remplaçant bien sûr NomColonne par le vrai nom de la colonne...)

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Ingénieur en électrotéchnique
    Inscrit en
    Mai 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur en électrotéchnique
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2013
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Je vous remercie beaucoup pour votre aide, vous m'avez vraiment aidé à finalisé mon projet de fin des études. Même si moi je suis pas un informaticien mais je suis ingénieur en électrotechnique, j'ai eu besoin de découvrir cet environnement de programmation et je ne le regrette point.

Discussions similaires

  1. [Débutant] problème d'intégration d'une bibliothèque sous Visual studio 2010
    Par IsaAdA dans le forum Visual Studio
    Réponses: 5
    Dernier message: 25/08/2013, 20h18
  2. [Débutant] Démarer une IHM avec Visual studio 2010 et WinForms
    Par JeanNoel53 dans le forum Windows Forms
    Réponses: 23
    Dernier message: 22/04/2012, 19h55
  3. Réponses: 4
    Dernier message: 19/05/2011, 15h06
  4. Réponses: 1
    Dernier message: 18/04/2011, 17h21
  5. portee d'une variable dans "visual studio"
    Par liloulinx dans le forum Débuter
    Réponses: 26
    Dernier message: 15/03/2010, 12h32

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