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.
Envoyé par
dijas
" 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 :
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 :
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 :
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 :
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 :
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 :
insert into Réglages(NomColonne) values (@value)
(en remplaçant bien sûr NomColonne par le vrai nom de la colonne...)
Partager