[VBA] Probléme ADO
Fermé
Poupy
-
2 mai 2009 à 15:11
Polux31 Messages postés 6917 Date d'inscription mardi 25 septembre 2007 Statut Membre Dernière intervention 1 novembre 2016 - 9 mai 2009 à 14:21
Polux31 Messages postés 6917 Date d'inscription mardi 25 septembre 2007 Statut Membre Dernière intervention 1 novembre 2016 - 9 mai 2009 à 14:21
9 réponses
michel_m
Messages postés
16603
Date d'inscription
lundi 12 septembre 2005
Statut
Contributeur
Dernière intervention
16 décembre 2023
3 303
2 mai 2009 à 16:30
2 mai 2009 à 16:30
Bonjour,
normal car tu ne t'es pas connecté à ta base
' à adapter
fichier = localisationdetabase & "\tabasemdb"
Set source= New ADODB.Connection
source;"Provider = Microsoft.Jet.OLEDB.4.0;" & _
"data source=" & fichier & ";"
----
et tu n'instancie ta requete:
set requete= new Adodb.Recordset
texte_sql="SELECT nomCli, vill....
Set requete = source.Execute(texte_SQL)
debug print requete
il ya peut être des parenthèses ou un point (trou de mémoire!)
-----
ton texte SQL est faux: WHERE villeCli = [Choisissez la ville]"
peut-^tre mais....:WHERE villeCli= [" & choisissez.. & "]
----
d'autre part la déclaration Dim source as ADODB.connection et dim requete as ADODB.recorset n'est pas un modèle de portabilité: à chaque changement d'ordi il faut vérifier si la bbliothèque ADO est cochée et qu'on est pas sur une version antérieure d' Access
emploie plutôt
Dim Source As Object, Requete As Object
...
Set Source = CreateObject("ADODB.Connection")
....
Set Requete = CreateObject("ADODB.Recordset")
Cordialement, Michel
normal car tu ne t'es pas connecté à ta base
' à adapter
fichier = localisationdetabase & "\tabasemdb"
Set source= New ADODB.Connection
source;"Provider = Microsoft.Jet.OLEDB.4.0;" & _
"data source=" & fichier & ";"
----
et tu n'instancie ta requete:
set requete= new Adodb.Recordset
texte_sql="SELECT nomCli, vill....
Set requete = source.Execute(texte_SQL)
debug print requete
il ya peut être des parenthèses ou un point (trou de mémoire!)
-----
ton texte SQL est faux: WHERE villeCli = [Choisissez la ville]"
peut-^tre mais....:WHERE villeCli= [" & choisissez.. & "]
----
d'autre part la déclaration Dim source as ADODB.connection et dim requete as ADODB.recorset n'est pas un modèle de portabilité: à chaque changement d'ordi il faut vérifier si la bbliothèque ADO est cochée et qu'on est pas sur une version antérieure d' Access
emploie plutôt
Dim Source As Object, Requete As Object
...
Set Source = CreateObject("ADODB.Connection")
....
Set Requete = CreateObject("ADODB.Recordset")
Cordialement, Michel
le code que tu me propose est tellement approximatif qu'il ne m'a pas aidé ...
D'autre parce que tu me propose :" Set requete = source.Execute(texte_SQL)
debug print requete "
ne marche pas
D'autre parce que tu me propose :" Set requete = source.Execute(texte_SQL)
debug print requete "
ne marche pas
Polux31
Messages postés
6917
Date d'inscription
mardi 25 septembre 2007
Statut
Membre
Dernière intervention
1 novembre 2016
1 204
8 mai 2009 à 19:12
8 mai 2009 à 19:12
Et pourtant tout est clairement expliqué. Je pense que l'approximation n'est pas dans la solution proposée ...
dapré la solution proposé, j arrive a sa. solution que ne marche toujours pas. (erreur indiqué sur : set Monrs = source.excecute
Sub requetebis()
Dim MaConnex As Adodb.Connection
Dim MonRs As Adodb.Recordset
Dim MaReq As String
Set MaConnex = New Adodb.Connection
MaConnex = CurrentProject.Connection
Set MonRs = New Adodb.Recordset
MaReq = "SELECT nomCli, villeCli " & "FROM Client " & "WHERE villeCli = " & "Aubagne " & ";"
Set MonRs = Source.Execute(MaReq)
Debug.Print MonRs
End Sub
'Commentaire: currentProject.connexion = "Provider Microsoft.ACE.OLEDB.12.0;user id = admin; data source = .........
End Sub
Sub requetebis()
Dim MaConnex As Adodb.Connection
Dim MonRs As Adodb.Recordset
Dim MaReq As String
Set MaConnex = New Adodb.Connection
MaConnex = CurrentProject.Connection
Set MonRs = New Adodb.Recordset
MaReq = "SELECT nomCli, villeCli " & "FROM Client " & "WHERE villeCli = " & "Aubagne " & ";"
Set MonRs = Source.Execute(MaReq)
Debug.Print MonRs
End Sub
'Commentaire: currentProject.connexion = "Provider Microsoft.ACE.OLEDB.12.0;user id = admin; data source = .........
End Sub
michel_m
Messages postés
16603
Date d'inscription
lundi 12 septembre 2005
Statut
Contributeur
Dernière intervention
16 décembre 2023
3 303
8 mai 2009 à 20:02
8 mai 2009 à 20:02
Fais du macramé, ça ira mieux
--
--
... faut que je trouve ... j'ai pas le choix ..
michel_m
Messages postés
16603
Date d'inscription
lundi 12 septembre 2005
Statut
Contributeur
Dernière intervention
16 décembre 2023
3 303
8 mai 2009 à 20:25
8 mai 2009 à 20:25
L'erreur se voit comme le nez au milieu de la figure...
--
--
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Comparaison: ce qui fait / ce que tu ma proposé:
fichier = localisationdetabase & "\tabasemdb"
Set source= New ADODB.Connection
source;"Provider = Microsoft.Jet.OLEDB.4.0;" & _
"data source=" & fichier & ";"
----
et tu n'instancie ta requete:
set requete= new Adodb.Recordset
texte_sql="SELECT nomCli, vill....
Set requete = source.Execute(texte_SQL)
debug print requete
il ya peut être des parenthèses ou un point (trou de mémoire!)
-----
ton texte SQL est faux: WHERE villeCli = [Choisissez la ville]"
peut-^tre mais....:WHERE villeCli= [" & choisissez.. & "]
-------------------------------------------------------------------------------
Sub requetebis()
Dim MaConnex As Adodb.Connection
Dim MonRs As Adodb.Recordset
Dim MaReq As String
Set MaConnex = New Adodb.Connection // Set source= New ADODB.Connection
MaConnex = CurrentProject.Connection // source;"Provider = Microsoft.Jet.OLEDB.4.0;" & _ "data source=" & fichier & ";"
Set MonRs = New Adodb.Recordset // set requete= new Adodb.Recordset
MaReq = "SELECT nomCli, villeCli " & "FROM Client " & "WHERE villeCli = " & "Aubagne " & ";" // texte_sql="SELECT nomCli, vill....
Set MonRs = Source.Execute(MaReq) // Set requete = source.Execute(texte_SQL)
Debug.Print MonRs // debug print requete
End Sub
les erreurs les plus évidente sont parfois les plus dure a trouvé ...
fichier = localisationdetabase & "\tabasemdb"
Set source= New ADODB.Connection
source;"Provider = Microsoft.Jet.OLEDB.4.0;" & _
"data source=" & fichier & ";"
----
et tu n'instancie ta requete:
set requete= new Adodb.Recordset
texte_sql="SELECT nomCli, vill....
Set requete = source.Execute(texte_SQL)
debug print requete
il ya peut être des parenthèses ou un point (trou de mémoire!)
-----
ton texte SQL est faux: WHERE villeCli = [Choisissez la ville]"
peut-^tre mais....:WHERE villeCli= [" & choisissez.. & "]
-------------------------------------------------------------------------------
Sub requetebis()
Dim MaConnex As Adodb.Connection
Dim MonRs As Adodb.Recordset
Dim MaReq As String
Set MaConnex = New Adodb.Connection // Set source= New ADODB.Connection
MaConnex = CurrentProject.Connection // source;"Provider = Microsoft.Jet.OLEDB.4.0;" & _ "data source=" & fichier & ";"
Set MonRs = New Adodb.Recordset // set requete= new Adodb.Recordset
MaReq = "SELECT nomCli, villeCli " & "FROM Client " & "WHERE villeCli = " & "Aubagne " & ";" // texte_sql="SELECT nomCli, vill....
Set MonRs = Source.Execute(MaReq) // Set requete = source.Execute(texte_SQL)
Debug.Print MonRs // debug print requete
End Sub
les erreurs les plus évidente sont parfois les plus dure a trouvé ...
michel_m
Messages postés
16603
Date d'inscription
lundi 12 septembre 2005
Statut
Contributeur
Dernière intervention
16 décembre 2023
3 303
9 mai 2009 à 08:23
9 mai 2009 à 08:23
"Le code que tu me propose est tellement approximatif qu'il ne m'a pas aidé ..."
Et tu crois que je vais t'aider en plus?
Dém.... toi tout seul
Et tu crois que je vais t'aider en plus?
Dém.... toi tout seul
désolé... je me suis un peu emporté, le fait que je n'arrive pas a avancé sur ce tp me stress un peu ...
bref j'ai trouvé une de mes erreurs :
Set MonRs = Source.Execute(MaReq) Devient Set MonRs = MaConnex.Execute(MaReq)
Mais une erreur apparait m'indiquant l'opération n'est pas autorisé si l'objet est fermé.
bref j'ai trouvé une de mes erreurs :
Set MonRs = Source.Execute(MaReq) Devient Set MonRs = MaConnex.Execute(MaReq)
Mais une erreur apparait m'indiquant l'opération n'est pas autorisé si l'objet est fermé.
Je doit maintenant corriger une erreur m'indiquant que mon Recordset n'est pas ouvert.
J'ai donc rajouté :
MonRs.Open MaReq, MaConnex, adOpenStatic
et encore un echec ^^
J'ai donc rajouté :
MonRs.Open MaReq, MaConnex, adOpenStatic
et encore un echec ^^
Merci beacoup pour m'avoir indiquez des éléments de réponse. J'ai donc pu enfin trouvé la solution :
Sub Marequete()
Dim MaConnex As New Connection
Dim MonRs As New Recordset
Dim MaReq As String
Set MaConnex = CurrentProject.Connection
MaReq = "select * from client"
Set MonRs.ActiveConnection = maConnex
MonRs.Open MaReq, MaConnex
MonRs.MoveFirst
While MonRs.EOF <> True
Debug.Print MonRs!nomCli & " " & MonRs!villeCli
MonRs.MoveNext
Wend
End Sub
Sub Marequete()
Dim MaConnex As New Connection
Dim MonRs As New Recordset
Dim MaReq As String
Set MaConnex = CurrentProject.Connection
MaReq = "select * from client"
Set MonRs.ActiveConnection = maConnex
MonRs.Open MaReq, MaConnex
MonRs.MoveFirst
While MonRs.EOF <> True
Debug.Print MonRs!nomCli & " " & MonRs!villeCli
MonRs.MoveNext
Wend
End Sub
Je post une nouvelle foi car j'avais oublié un petit quelque chose ^^
Sub RequetteVille()
Dim maConnex As New Connection
Dim monRs As New Recordset
Dim maReq As String
Dim vVille As String
Set maConnex = CurrentProject.Connection
maReq = "select * from client"
Set monRs.ActiveConnection = maConnex
monRs.Open maReq, maConnex
vVille = InputBox("Indiquez la ville")
monRs.MoveFirst
While monRs.EOF <> True
If monRs!villeCli = vVille Then
Debug.Print monRs!nomCli & " " & monRs!villeCli
End If
monRs.MoveNext
Wend
End Sub
Sub RequetteVille()
Dim maConnex As New Connection
Dim monRs As New Recordset
Dim maReq As String
Dim vVille As String
Set maConnex = CurrentProject.Connection
maReq = "select * from client"
Set monRs.ActiveConnection = maConnex
monRs.Open maReq, maConnex
vVille = InputBox("Indiquez la ville")
monRs.MoveFirst
While monRs.EOF <> True
If monRs!villeCli = vVille Then
Debug.Print monRs!nomCli & " " & monRs!villeCli
End If
monRs.MoveNext
Wend
End Sub
Polux31
Messages postés
6917
Date d'inscription
mardi 25 septembre 2007
Statut
Membre
Dernière intervention
1 novembre 2016
1 204
9 mai 2009 à 14:21
9 mai 2009 à 14:21
Et ben tu vois ... quand tu veux te donner la peine ... tu y arrives très bien ... ^^
;o)
;o)