Récupérer lignes datagridview

sistaroro -  
Scalpweb Messages postés 1483 Statut Membre -
Bonjour,
j'ai un petit souci. Voila mon problème: j'ai un datagridview ou il y a des données. Et en fait je veux insérer une partie de ces données dans une table.
Pour cela je le fait avec une boucle mais seulement la première ligne du datagridview est insérée dans la base de données. Voici le code. Merci d'avance.





Public Sub insertion_ligne_facturebdd(ByVal numero_facture AsInteger)



'Déclaration de la connexion à la base de données'
Dim MaConnexion As OleDbConnection = New OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data source=librairie.mdb")


Dim Macommande As OleDbCommand = MaConnexion.CreateCommand()

Dim i AsInteger

Dim j AsInteger

j = ajouter_facture.grille.Rows.Count

For i = 0 To i = j


'Conversion de la quantité en integer'
Dim quantite AsInteger

quantite = CType(ajouter_facture.grille(3, i).Value.ToString, Integer)


'Conversion du numéro du produit'
Dim num_produit AsInteger

num_produit = CType(ajouter_facture.grille(0, i).Value.ToString, Integer)



'Commande avec la requete d'insertion dans la table composer' Macommande.CommandText = "INSERT INTO composer(num_facture,num_produit,quantité_achetée) VALUES(" & numero_facture & "," & num_produit & "," & quantite & ") ;"

Dim MyDataAdapter AsNew OleDbDataAdapter(Macommande)

'On fait appel au dataAdapter puis on ouvre la connexion


MaConnexion.Open()


'on éxécute la commande
MyDataAdapter.UpdateCommand = Macommande

MyDataAdapter.UpdateCommand.ExecuteNonQuery()


Dim Macommande3 As OleDbCommand = MaConnexion.CreateCommand()

'Commande avec la requete pour retirer le stock dun produit'
Macommande3.CommandText = "UPDATE produit SET stock_actuel=(stock_actuel-" & quantite & ") WHERE num_produit=" & num_produit & ";"


Dim MyDataAdapter3 AsNew OleDbDataAdapter(Macommande3)

'On fait appel au dataAdapter puis on ouvre la connexion

'on éxécute la commande

MyDataAdapter3.UpdateCommand = Macommande3

MyDataAdapter.UpdateCommand.ExecuteNonQuery()



'et on ferme la connexion
MaConnexion.Close()

Next



End Sub

22 réponses

Scalpweb Messages postés 1483 Statut Membre 43
 
L'erreur est ici :

For i = 0 To i = j

Il faut écrire :

For i = 0 To j
0
sistaroro
 
Merci beaucoup, mais maintenant j'ai un autre souci. Je veux convertir le texte contenu dans certaines cellules en integer.Mais je ne sais pas comment faire pour récupérer la valeur de type string.
0
Scalpweb Messages postés 1483 Statut Membre 43
 
En VB, les conversions sont implicites.

Tu peux très bien faire :

var_Integer = var_String1 + var_String2

Ou :

var_String = var_Int*var_Int
0
sistaroro
 
je n'ai pas très bien compris.je veux récupérer le texte qui est dans la cellule et le convertir en integer pour l'insérer dans la base de données
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Apparemment, tu as déjà réussi :

num_produit = CType(ajouter_facture.grille(0, i).Value.ToString, Integer)  
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
sistaroro
 
ben sa ne fonctionne pas.je veux récupérer le numéro des produits qui existent dans la base et j'ai un message d'erreur(Vous ne pouvez pas ajouter ou modifier un enregistrement car l'enregistrement associé est requis dans la table 'PRODUIT'.). alors je pense que sa ne me retourne pas la valeur ki est contenue dans les cellules.merci davance
0
sistaroro
 
En fait, sa me retourne 0 pour le numéro du produit et la quantité alors que les valeurs affichées c'est 2 pour le produit et 1 pour la quantité
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Tu es sur que tu ne pointes pas les mauvaises cases ?
0
sistaroro
 
ben je pense que non, pour la quantité je fais :

quantite = CType(grille(3, i).Value, Integer) avec i le nombre de lignes de la facture
et le numéro du produit
num_produit = CType(grille(0, i).Value, Integer)
et je fais une boucle pour de i=0 jusqau nombre de lignes.

Sur le datagridview, la quantité est la 4eme colonne et le numéro du produit la 1ere colonne.

j'ai cru comprendre que l'on commencait a compter a partir de 0.
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Oui c'est bien ça...

JE ne suis pas expert en VBA, et la je sèche...

jvais réfléchir.

passe moi un lien vers ton fichier au pire
0
sistaroro
 
C'est du VB 2005.euh ben mon projet est sur mon pc.je n'ai pas de lien
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Tu ne peux pas l'uploader sur un serveur ?
0
sistaroro
 
quel serveur par exemple?
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Laisse tomber...

On va faire un truc, écrit ce code :

j = ajouter_facture.grille.Rows.Count

For i = 0 To i = j

For i = 1 to 5
For j = 1 To 5
msgbox i & ";" & j & "->" & ajouter_facture.grille(i,j).value
Next
Next

Et regardes pour quels valeurs tu vois aparaitre tes valeurs.
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Pour que tu gagnes un peu de temps, en VB2005 :

quantite = CType(ajouter_facture.grille(3, i).Value.ToString, Integer)

peut s'écrire :

quantite = ajouter_facture.grille(3, i).Value
0
sistaroro
 
après la flèche je n'ai aucune valeur qui saffiche
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Et avec ce code là ?

For i = 1 to 5
For j = 1 To 10
msgbox i & ";" & j & "->" & ajouter_facture.grille(i,j).value.ToString
Next
Next
0
sistaroro
 
sa m'affiche les valeurs qui sont dans les cellules.dans mon cas qu'est ce qu'il faut faire alors?
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Il faut savoir les valeurs i et j correspondantes au valeurs que tu veux...

Pour être sur que ta boucle pointe bien vers les bonnes.

Tu comprends ?
0
sistaroro
 
oui mais une fois que je sais,
le numéro du produit c'est (0,i) et pour la quantité c'est (3,i) .
Je dois faire 2 pour imbriqués ou un seul suffit?
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Ton code devrait marcher...

Essayes de rajouter :

msgbox quantite & "-" & num_produit

Après :
Dim num_produit AsInteger

num_produit = CType(ajouter_facture.grille(0, i).Value.ToString, Integer) 


Est-ce les bonnes valeurs qui s'affichent ?
0
sistaroro
 
sa a l'air de fonctionner mais sa me donne 3 msgbox alors qu'il n'y a que 2 lignes dans le datagridview
0
Scalpweb Messages postés 1483 Statut Membre 43
 
Remplace :

j = ajouter_facture.grille.Rows.Count

Par

j = ajouter_facture.grille.Rows.Count -1

En effet, l'indice commence à 0, donc le dernier indice est égal au nombre d'indice -1.

En tout cas, si ça marche, c'est que l'erreur vient d'ailleurs...
0