Mise à jour VB6 et Access 2007 avec requête SQL
Fermé
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
-
Modifié par Jeff le 5/11/2014 à 17:49
f894009 Messages postés 17185 Date d'inscription dimanche 25 novembre 2007 Statut Membre Dernière intervention 15 avril 2024 - 29 mai 2014 à 10:44
f894009 Messages postés 17185 Date d'inscription dimanche 25 novembre 2007 Statut Membre Dernière intervention 15 avril 2024 - 29 mai 2014 à 10:44
A voir également:
- Mise à jour VB6 et Access 2007 avec requête SQL
- Mise à jour pilote - Guide
- Mise a jour airpods - Guide
- Mise a jour windows 10 - Guide
- Mise a jour xiaomi - Guide
- Mise a jour chrome - Guide
28 réponses
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
21 mai 2014 à 10:17
21 mai 2014 à 10:17
Bonjour,
contre celle concernant Case = Cette instruction n'existe pas dans votre code, vous avez ecrit Case Else qui devrait faire ce que vous attendez.
Un simple
Il manque Rs.Edit pour chaque Rs.Udate. Si vous avez plusieurs fois le meme nom, comment vous faiies ????
contre celle concernant Case = Cette instruction n'existe pas dans votre code, vous avez ecrit Case Else qui devrait faire ce que vous attendez.
Un simple
If TMatiere <> RS![Matiere] Then ....... Else ....... End ifaurait suffi.
Il manque Rs.Edit pour chaque Rs.Udate. Si vous avez plusieurs fois le meme nom, comment vous faiies ????
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
1
21 mai 2014 à 13:11
21 mai 2014 à 13:11
Bonjour l'Ami,
Merci pour votre attention.
Même avec la condition If .... then ..... Else ..... end if, le resultat était toujours le même. Car c'est cette condition que j'ai essayé en premier lieu.
Concernant la RS.EditMode ( Je crois ) je ne sais pas comment l'utiliser. Si vous m'éclairiez sur ce point je vous en serai reconnaissant.
Concernant le même nom, je crois ce n'est pas un problème. Car Sur la TableNom c'est le cumul des note qui gère
Merci encore pour votre aide
Merci pour votre attention.
Même avec la condition If .... then ..... Else ..... end if, le resultat était toujours le même. Car c'est cette condition que j'ai essayé en premier lieu.
Concernant la RS.EditMode ( Je crois ) je ne sais pas comment l'utiliser. Si vous m'éclairiez sur ce point je vous en serai reconnaissant.
Concernant le même nom, je crois ce n'est pas un problème. Car Sur la TableNom c'est le cumul des note qui gère
Merci encore pour votre aide
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
21 mai 2014 à 15:14
21 mai 2014 à 15:14
Re,
Concernant la RS.EditMode ( Je crois ) ----> Autant pour moi, si requete sql, pas de passage en mode edition pour modifier les champs d'un enregistrement
un exemple qui marche chez moi avec une base simple
Concernant la RS.EditMode ( Je crois ) ----> Autant pour moi, si requete sql, pas de passage en mode edition pour modifier les champs d'un enregistrement
un exemple qui marche chez moi avec une base simple
Private Sub CommandButton1_Click()
Texte = Me.Controls("Textbox" & 4)
Sql = "select * from BdD_Bon where [Group]='" & Texte & "'"
rs.Open Sql, conn, 3, 3
If rs.EOF And rs.BOF Then
MsgBox "Existe pas!!!"
Else
If Texte <> rs![Group] Then
rs![numero] = 0
rs![Group] = ""
rs![Matricule] = 0
Else
rs![numero] = Texte
rs![Group] = "AZER"
rs![Matricule] = 99999
End If
rs.Update
End If
End Sub
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
1
22 mai 2014 à 02:02
22 mai 2014 à 02:02
Bonjour l'Ami,
Je vous donnerai plus d'explications pour vous permettre de bien cerner mon problème
Voilà :
il y'a tout d'abord une Table où sont enregistrées les données ( TablePrincipale )
elle contient 4 colonnes
0 = Nordre
1=Nom
2=Matiere
3=Note
avec comme clé primaire le NOrdre
ensuite
il y'a la table secondaire 1 ( TableNom) .Elle contient aussi 4 Colonnes
0=Nom
1=NOrdre
2=Matiere
3=Note
Déjà dans cette table la colonne 1 [Nom] est remplie par plusieurs noms différents à partir d'une fenêtre de paramétrage ( Nom est considéré comme Index ), avec comme clé primaire le Nom
ensuite
il y'a la Table secondaire 2 ( TableMatière ). Elle contient elle aussi 4 Colonnes
0=Matiere
1=NOrdre
2=Nom
3=Note
Aussi la colonne 1 [Matiere] est déjà remplie par les différentes matières à partir de la fenêtre du parametrage ( Matiere est considérée ici comme Index), avec comme clé primaire la Matiere
au moment de la saisie générale, les codes saisis sont comme suit
la Feuille de saisie
Ces codes sont ici pour la saisie générale
seulement en cas d'erreur de saisie, détectée après, il y' a une fenêtre de recherche qui renvoie à la fenêtre de mise à jour.
Supposons que la saisie générale a donné ce qui suit
sur la TablePrincipale
NOrdre Nom Matiere Note
1 XXXX Math 14,45
Sur la TableNom ( Déjà la colonne 0 est pleine par les Noms )
Nom NOrdre Matiere Note
XXXX 1 Math 14,45
YYYY
ZZZZ
WWW
Sur la TableMatiere ( Déjà la Colonne 0 est pleine par les matières )
Matiere NOrdre Nom Note
Math 1 XXX 14,45
Phisique
Chimie
Science
Ceci étant exposé
Supposons que l'erreur détectée est comme suite
au lieu de saisir YYYY on a saisi par erreur XXX ,
et
au lieu de saisir Chimie on a saisi Math
on veut corriger ces deux erreurs
les codes écris sur la feuille de modification est comme suit
sur la TablePrincipale avec les codes dessus la correction est réussie
mais sur la TableNom et la TableMatiere , la suppression des données saisies qui sont supprimées mais la correction est ignorée
c'est à dire
sur la TableNom NOrdre Math 14,45 ( Saisis sur la ligne de XXX ) sont supprimé, mais sur la ligne de YYY rien n'est enregistrés
la même chose se passe sur la ligne matire dans la ( TableMatiere )
les données saisie par erreur sur la ligne de Math sont supprimées, mais rien n'est enregistré sur la ligne de Chimie
Voilà mon problème
J'espère être clair pour vous permettre de bien situer le problème et me donner une solution viable.
Merci pour votre patience
A plus l'Ami
Je vous donnerai plus d'explications pour vous permettre de bien cerner mon problème
Voilà :
il y'a tout d'abord une Table où sont enregistrées les données ( TablePrincipale )
elle contient 4 colonnes
0 = Nordre
1=Nom
2=Matiere
3=Note
avec comme clé primaire le NOrdre
ensuite
il y'a la table secondaire 1 ( TableNom) .Elle contient aussi 4 Colonnes
0=Nom
1=NOrdre
2=Matiere
3=Note
Déjà dans cette table la colonne 1 [Nom] est remplie par plusieurs noms différents à partir d'une fenêtre de paramétrage ( Nom est considéré comme Index ), avec comme clé primaire le Nom
ensuite
il y'a la Table secondaire 2 ( TableMatière ). Elle contient elle aussi 4 Colonnes
0=Matiere
1=NOrdre
2=Nom
3=Note
Aussi la colonne 1 [Matiere] est déjà remplie par les différentes matières à partir de la fenêtre du parametrage ( Matiere est considérée ici comme Index), avec comme clé primaire la Matiere
au moment de la saisie générale, les codes saisis sont comme suit
la Feuille de saisie
SQLs="Select * from TablePrincipale where NOrdre=" & TNOrdre &""
if RS.State=adStateOpen Then RS.Close
RS.Open SQLs, DB, adOpenKeySet, adLockPessimistic
if RS.EOF then
Goto Oks:
else
Msgbox"Désolé, ce Numéro existe déjà"
exit sub
end if
Oks:
RS.addNew
RS![NOrdre]=TNOrdre
RS![Nom]=TNom
RS![Matiere]=TMatiere
RS![Note]=TNote
RS.Update
'-------------------------------
Dim N
N=CStr(TNom)
SQLs="Select * from TableNom where Nom=' " & TNom &" ' "
if RS.State=adStateOpen Then RS.Close
RS.Open SQLs, DB, adOpenKeySet, adLockPessimistic
if TNom = RS![Nom] Then
RS![NOrdre]=TNOrdre
RS![Matiere]=TMatiere
RS![Note]=TNote
RS.Update
End if
'---------------------------------
Dim M
M=CStr(TMatiere)
SQLs="Select * from TableMatiere where Matiere=' " & TMatiere &" ' "
if RS.State=adStateOpen Then RS.Close
RS.Open SQLs, DB, adOpenKeySet, adLockPessimistic
if TMatiere = RS![Matiere] Then
RS![NOrdre]=TNOrdre
RS![Matiere]=TMatiere
RS![Note]=TNote
RS.Update
End if
Ces codes sont ici pour la saisie générale
seulement en cas d'erreur de saisie, détectée après, il y' a une fenêtre de recherche qui renvoie à la fenêtre de mise à jour.
Supposons que la saisie générale a donné ce qui suit
sur la TablePrincipale
NOrdre Nom Matiere Note
1 XXXX Math 14,45
Sur la TableNom ( Déjà la colonne 0 est pleine par les Noms )
Nom NOrdre Matiere Note
XXXX 1 Math 14,45
YYYY
ZZZZ
WWW
Sur la TableMatiere ( Déjà la Colonne 0 est pleine par les matières )
Matiere NOrdre Nom Note
Math 1 XXX 14,45
Phisique
Chimie
Science
Ceci étant exposé
Supposons que l'erreur détectée est comme suite
au lieu de saisir YYYY on a saisi par erreur XXX ,
et
au lieu de saisir Chimie on a saisi Math
on veut corriger ces deux erreurs
les codes écris sur la feuille de modification est comme suit
Sub CmdModifier_Click ()
If NOrdre = TNOrdre then
Goto Ne_Fais_Rien :
end if
SQLs="Select * TablePrincipale where NOrdre = " & TNOrdre &""
if Rss.State=adStateOpen Then Rss.Close
Rss.Open SQLs, DB, adOpenKeySet, adLockPessimistic
if Rss.EOF then
Goto Oks:
else
msgbox" Ce Numero Existe "
exit sub
end if
Oks:
'-------
Ne_Fais_Rien:
ActuMsg=msgbox("Voulez vous modofier ?",VBquestion+vbYesNo,)
if AcuMsg=vbYes then
'-----l'Actualisation de la TablePrincipale
RS![Nom]=TNom
RS![Matiere]=TMatiere
RS![Note]=TNote
RS.Update
'--------------------------------------------
Dim N
N=CStr(TNom)
SQLs="Select * from TableNom where Nom = '" & CStr(TNom) &"'"
if Rss.State=adStateOpen Then Rss.Close
Rss.Open SQLs, DB, adOpenKeySet, adLockPessimistic
'-----l'Actualisation de la TableNom
if TNom <> RS![Nom] then
RS![NOrdre]=0
RS![Matiere]=""
RS![Note]=0
Else
RS![NOrdre]=TNOrdre
RS![Matiere]=TMatiere
RS![Note]=TNote
RS.Update
end If
'-------------------------------------------------
'-----l'Actualisation de la TableMatiere
Dim M
M=CStr(TMatiere)
SQLs="Select * from TableMatiere where Matiere = '" & CStr(TMatiere) &"'"
if Rss.State=adStateOpen Then Rss.Close
Rss.Open SQLs, DB, adOpenKeySet, adLockPessimistic
if TMatiere <> RS![Matiere] Then
RS![NOrdre]
RS![Nom]=""
RS![Note]=0
Else
Rs![NOrdre]
RS![Nom]=TNom
RS![Note]=TNote
RS.Update
end if
FRecherche.Show
Load me
end if
end sub
sur la TablePrincipale avec les codes dessus la correction est réussie
mais sur la TableNom et la TableMatiere , la suppression des données saisies qui sont supprimées mais la correction est ignorée
c'est à dire
sur la TableNom NOrdre Math 14,45 ( Saisis sur la ligne de XXX ) sont supprimé, mais sur la ligne de YYY rien n'est enregistrés
la même chose se passe sur la ligne matire dans la ( TableMatiere )
les données saisie par erreur sur la ligne de Math sont supprimées, mais rien n'est enregistré sur la ligne de Chimie
Voilà mon problème
J'espère être clair pour vous permettre de bien situer le problème et me donner une solution viable.
Merci pour votre patience
A plus l'Ami
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
22 mai 2014 à 11:17
22 mai 2014 à 11:17
Bonjour,
J'ai compris votre probleme, table Matiere et Nom il n'y a pas de mise a jour sur correction(s).
Parcontre, choses qui me chagrinent un peu:
vous faites des requetes en partant de variables et vous testez si dans le recordset c'est different de la variable que vous avez utilisee pour creer ce recordset
Pouvez-vous mettre a dispo votre projet complet en changent le noms s'il y en a
J'ai compris votre probleme, table Matiere et Nom il n'y a pas de mise a jour sur correction(s).
Parcontre, choses qui me chagrinent un peu:
vous faites des requetes en partant de variables et vous testez si dans le recordset c'est different de la variable que vous avez utilisee pour creer ce recordset
SQLs="Select * from TableNom where Nom = '" & CStr(TNom) &"'"
et
if TNom <> RS![Nom] then
SQLs="Select * from TableMatiere where Matiere = '" & CStr(TMatiere) &"'"
et
if TMatiere <> RS![Matiere] Then
Pouvez-vous mettre a dispo votre projet complet en changent le noms s'il y en a
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
23 mai 2014 à 06:47
23 mai 2014 à 06:47
Bonjour,
le .vbw ne me sert a rien.
le .vbw ne me sert a rien.
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
1
23 mai 2014 à 14:40
23 mai 2014 à 14:40
Bonjour l'Ami,
Je n'est pas compris votre phrase le .vbw ne me sert a rien.
Si je vous n'aviez pas reçu mon dossier de le renvoie une autre fois
A plus
Je n'est pas compris votre phrase le .vbw ne me sert a rien.
Si je vous n'aviez pas reçu mon dossier de le renvoie une autre fois
A plus
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
23 mai 2014 à 14:47
23 mai 2014 à 14:47
Re,
Pas de dossier dans ce que vous avez mis a dispo, seulement un .vbw
Pas de dossier dans ce que vous avez mis a dispo, seulement un .vbw
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
1
23 mai 2014 à 15:02
23 mai 2014 à 15:02
Re Bonjour l'Ami
Veuilez trouver mon dossier sur ce lien
https://www.cjoint.com/?0ExpaG8k7cW
A binetôt.
Avisez moi si jamais le même problème persistait
Veuilez trouver mon dossier sur ce lien
https://www.cjoint.com/?0ExpaG8k7cW
A binetôt.
Avisez moi si jamais le même problème persistait
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
23 mai 2014 à 15:11
23 mai 2014 à 15:11
Re,
meme chose !!!!!!!!
Votre projet est dans un repertoire, compressez le repertoire
meme chose !!!!!!!!
Votre projet est dans un repertoire, compressez le repertoire
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
1
23 mai 2014 à 16:03
23 mai 2014 à 16:03
Re
Veuillez m'excuser . je vous l'ai dis, nul en informatique
https://www.cjoint.com/?0ExqcvWQ3zF
je l'ai compressé. J'espère que cette fois est la bonne
a plus
Veuillez m'excuser . je vous l'ai dis, nul en informatique
https://www.cjoint.com/?0ExqcvWQ3zF
je l'ai compressé. J'espère que cette fois est la bonne
a plus
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
23 mai 2014 à 16:21
23 mai 2014 à 16:21
Re,
C'est bon. Je vous tiens au courant.
A+
C'est bon. Je vous tiens au courant.
A+
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
23 mai 2014 à 17:03
23 mai 2014 à 17:03
Re,
Structure de base de donnees un peu curieuse:
Table TableNoms: que viennent faire la Matiere et la note dans cette table ??????
Table TableMatieres: que viennent faire le Nom et la note dans cette table ??????
et comme je l'ai deja ecrit, comment faites vous pour les personnes de meme nom
Il faudrait commencer par terminer la saisie des noms avant de penser a voir comment rectifier les erreurs de saisie des notes et matieres
De plus, la saisie des notes par matieres est un peu confuse. Y a plus simple.
A+
Structure de base de donnees un peu curieuse:
Table TableNoms: que viennent faire la Matiere et la note dans cette table ??????
Table TableMatieres: que viennent faire le Nom et la note dans cette table ??????
et comme je l'ai deja ecrit, comment faites vous pour les personnes de meme nom
Il faudrait commencer par terminer la saisie des noms avant de penser a voir comment rectifier les erreurs de saisie des notes et matieres
De plus, la saisie des notes par matieres est un peu confuse. Y a plus simple.
A+
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
1
23 mai 2014 à 23:14
23 mai 2014 à 23:14
Re,
Concernant la saisie des noms. J'ai prévu d'attribuer un code pour chaque
nom.
concernant la TableNoms , la Matiere et la Note y sont pour me permettre
d'appeler la note pour chaque nom ou la matière pour chauqe nom( si je ne me trompe pas )
ainsi pour la TableMatieres.
Que pensez vous ?
A plus l'Ami
Concernant la saisie des noms. J'ai prévu d'attribuer un code pour chaque
nom.
concernant la TableNoms , la Matiere et la Note y sont pour me permettre
d'appeler la note pour chaque nom ou la matière pour chauqe nom( si je ne me trompe pas )
ainsi pour la TableMatieres.
Que pensez vous ?
A plus l'Ami
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
Modifié par f894009 le 24/05/2014 à 07:54
Modifié par f894009 le 24/05/2014 à 07:54
Bonjour,
J'ai prévu d'attribuer un code pour chaque
nom. Non, vous faites un test si meme nom
Les tables Nom et Matieres ne doivent pas contenir d'autres informations que celles qui les concernent.
Il n'y a qu'une seule a mettre a jour pour la saisie ou rectification de notes: TableNotes
J'ai prévu d'attribuer un code pour chaque
nom. Non, vous faites un test si meme nom
MsgBox "Ce Nom est déjà saisi"et pas d'enregistrement
Les tables Nom et Matieres ne doivent pas contenir d'autres informations que celles qui les concernent.
Il n'y a qu'une seule a mettre a jour pour la saisie ou rectification de notes: TableNotes
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
1
24 mai 2014 à 13:58
24 mai 2014 à 13:58
Bonjour,
Après votre remarque ("Structure de base de donnees un peu curieuse: ")
J'ai revu la structure de ma BD . Je n'ai pas encore terminé, une faite, je mettrai
à votre disposition mon petit projet
Merci pour votre attention
Après votre remarque ("Structure de base de donnees un peu curieuse: ")
J'ai revu la structure de ma BD . Je n'ai pas encore terminé, une faite, je mettrai
à votre disposition mon petit projet
Merci pour votre attention
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
1
24 mai 2014 à 16:34
24 mai 2014 à 16:34
Re,
Je mets à votre disposition mon petit projet, revu suite à vos conseils.
j'aimerai bien que vous y jetiez un coup d'oeil et me dire votre avis.
l'Etape prochaine, je tenterai de calculer les cumuls
1 : des notes par Etudiant
2 : des notes par Etudiant et par matières
A plus et Merci pour tout
https://www.cjoint.com/?0EyqDrAUsic
Je mets à votre disposition mon petit projet, revu suite à vos conseils.
j'aimerai bien que vous y jetiez un coup d'oeil et me dire votre avis.
l'Etape prochaine, je tenterai de calculer les cumuls
1 : des notes par Etudiant
2 : des notes par Etudiant et par matières
A plus et Merci pour tout
https://www.cjoint.com/?0EyqDrAUsic
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
24 mai 2014 à 16:36
24 mai 2014 à 16:36
Re,
projet et base modifies pour noms identiques et pas meme prenom, ai simplifie correction saisie, ai ajoute des tests sur mise a jours Eleves, Matiere, Saisie Notes et correction Saisie Note
https://www.cjoint.com/?DEyqHOzppqE
A+
projet et base modifies pour noms identiques et pas meme prenom, ai simplifie correction saisie, ai ajoute des tests sur mise a jours Eleves, Matiere, Saisie Notes et correction Saisie Note
https://www.cjoint.com/?DEyqHOzppqE
A+
mohalesage
Messages postés
147
Date d'inscription
mercredi 20 février 2013
Statut
Membre
Dernière intervention
31 décembre 2015
1
25 mai 2014 à 01:41
25 mai 2014 à 01:41
Bonjour l'Ami
merci pour votre attention
merci pour votre attention
f894009
Messages postés
17185
Date d'inscription
dimanche 25 novembre 2007
Statut
Membre
Dernière intervention
15 avril 2024
1 702
25 mai 2014 à 10:30
25 mai 2014 à 10:30
Bonjour,
Dans ce que je vous ai mis a dispo, il y a un petit probleme, en faisant le menage du repertoire j'ai supprime la form EditionSaisie que j'ai modifiee avec Nom_Prenom.
Dans votre nouveau projet, si le CNE est unique, il doit etre la cle primaire de la table et vous n'avez pas besoin du NOrdre. Par contre il faut qu'a chaque fois vous ayez ce numero avec le nom sinon comment reconnaitre les personnes de meme nom
Dans ce que je vous ai mis a dispo, il y a un petit probleme, en faisant le menage du repertoire j'ai supprime la form EditionSaisie que j'ai modifiee avec Nom_Prenom.
Dans votre nouveau projet, si le CNE est unique, il doit etre la cle primaire de la table et vous n'avez pas besoin du NOrdre. Par contre il faut qu'a chaque fois vous ayez ce numero avec le nom sinon comment reconnaitre les personnes de meme nom