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

Macros et VBA Excel Discussion :

Fermeture connexion Access


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 73
    Points : 38
    Points
    38
    Par défaut Fermeture connexion Access
    Bonjour, Code qui fonctionne, permettant de filtrer une connexion Query vers une base Access, en revanche je ne parviens pas à trouver la solution pour couper la connexion avec la BDD après rafraichissement. (afin que la base soit dispo pour un autre utilisateur)... Des solutions? Merci d'avance!....


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    Sub REQSQL()
     
    '-------------------------------------------------PRINCIPE DE FONCTIONNEMENT----------------------------------------------------'
    '                                                                                                                               '
    ' Permet d'extraire des données d'une requête/table selon une variable précise (exemple convention)                             '                                             '
    '                                                                                                                               '
    '-------------------------------------------------------------------------------------------------------------------------------'
     
    Dim Nomconnect As Variant   'Nom de la connexion établie dans excel
    Dim connect As Variant      'Chemin et nom de la BDD Access
    Dim reqconv As Variant      'Emplacement de la variable recherchée
    Dim dimconv As Variant      'Dimension de la table/requête selectionnée
    Dim rq As Variant           'table/requête selectionnée
    Dim cmdsql As Variant       'Commande SQL
     
    Application.ScreenUpdating = False
     
     '                                                        **
     '                                                    **********
     '                                                        **
    '----------------------------------------------------PARAMETRAGES------------------------------------------------------
     
    Nomconnect = "DataTest - CONDITIONS"
    connect = "\\mg21\DataTest.accdb"
    reqconv = ActiveWorkbook.Worksheets("CONTRAT").Range("C3").Value
    dimconv = "CONV"
    rq = "CONDITIONS"
    cmdsql = "SELECT * FROM " & rq & " WHERE " & rq & "." & dimconv & " = (""" & reqconv & """)" 
     
     '                                                        **
     '                                                    **********
     '                                                        **
    '-------------------------------------------------------REQUETE----------------------------------------------------------
     
     
        With ActiveWorkbook.Connections(Nomconnect).OLEDBConnection
            .CommandText = Array(cmdsql)
            .Connection = Array("OLEDB;Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" & connect)
            .ServerCredentialsMethod = xlCredentialsMethodIntegrated
        End With
     
        ActiveWorkbook.Connections(Nomconnect).Refresh
     
    '-------------------------------------------------------FIN--------------------------------------------------------------
     
        Application.ScreenUpdating = True
     
    End Sub

  2. #2
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 73
    Points : 38
    Points
    38
    Par défaut Fermer une connexion Oledb
    J'ai écrit ce code, il fonctionne très bien, mais je ne parviens pas à fermer la connexion avec ma base (Access), tant que le fichier Excel est ouvert.

    J'aimerai que la connexion se ferme après le rafraichissement : merci par avance pour votre aide quant à ce dernier point!!!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    Sub REQSQL()
     
    '-------------------------------------------------PRINCIPE DE FONCTIONNEMENT----------------------------------------------------'
    '                                                                                                                               '
    ' Permet d'extraire des données d'une requête/table selon une variable précise (exemple convention)                             '                                             '
    '                                                                                                                               '
    '-------------------------------------------------------------------------------------------------------------------------------'
     
    Dim Nomconnect As Variant   'Nom de la connexion établie dans excel
    Dim connect As Variant      'Chemin et nom de la BDD Access
    Dim reqconv As Variant      'Emplacement de la variable recherchée
    Dim dimconv As Variant      'Dimension de la table/requête selectionnée
    Dim rq As Variant           'table/requête selectionnée
    Dim cmdsql As Variant       'Commande SQL
     
    Application.ScreenUpdating = False
     
     '                                                        **
     '                                                    **********
     '                                                        **
    '----------------------------------------------------PARAMETRAGES------------------------------------------------------
     
    Nomconnect = "DataTest - CONDITIONS"
    connect = "\\mg21\DataTest.accdb"
    reqconv = ActiveWorkbook.Worksheets("CONTRAT").Range("C3").Value
    dimconv = "CONV"
    rq = "CONDITIONS"
    cmdsql = "SELECT * FROM " & rq & " WHERE " & rq & "." & dimconv & " = (""" & reqconv & """)" 
     
     '                                                        **
     '                                                    **********
     '                                                        **
    '-------------------------------------------------------REQUETE----------------------------------------------------------
     
     
        With ActiveWorkbook.Connections(Nomconnect).OLEDBConnection
            .CommandText = Array(cmdsql)
            .Connection = Array("OLEDB;Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" & connect)
            .ServerCredentialsMethod = xlCredentialsMethodIntegrated
        End With
     
        ActiveWorkbook.Connections(Nomconnect).Refresh
     
    '-------------------------------------------------------FIN--------------------------------------------------------------
     
        Application.ScreenUpdating = True
     
    End Sub

  3. #3
    Expert éminent

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 073
    Points : 9 853
    Points
    9 853
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    la méthode Delete ?

    Simple lecture de l'aide , je n'ai jamais utilisé ce type de connexion

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 73
    Points : 38
    Points
    38
    Par défaut
    J'ai essayé avec les méthodes delete et close, ça ne fonctionne pas (erreur 438)

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 73
    Points : 38
    Points
    38
    Par défaut
    La méthode delete fonctionne, mais çela supprime la liaison de mon classeur. - n'y a-t-il pas une autre méthode pour fermer la connexion sans la supprimer? j'ai essayé avec Close mais erreur 438

  6. #6
    Invité
    Invité(e)
    Par défaut
    Nom : Sans titre.png
Affichages : 822
Taille : 60,2 Ko

  7. #7
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Développeur VBA/C#/VB.Net/Power Platform
    Inscrit en
    Juillet 2007
    Messages
    14 594
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur VBA/C#/VB.Net/Power Platform
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 594
    Points : 34 263
    Points
    34 263
    Par défaut
    Salut,

    pour fermer une connexion, tu peux utiliser la methode Delete

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ActiveWorkbook.Connections(NomConnect).Delete
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  8. #8

  9. #9
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 73
    Points : 38
    Points
    38
    Par défaut
    ok ça fonctionne!

  10. #10
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 73
    Points : 38
    Points
    38
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    Sub REQSQL()
     
    '-------------------------------------------------PRINCIPE DE FONCTIONNEMENT----------------------------------------------------'
    '                                                                                                                               '
    ' Permet d'extraire des données d'une requête/table selon une variable précise (exemple convention)                             '                                             '
    '                                                                                                                               '
    '-------------------------------------------------------------------------------------------------------------------------------'
     
    Dim Nomconnect As Variant   'Nom de la connexion établie dans excel
    Dim Piloteodc As Variant    'liaison du pilote odc (créer liaison enregistrer sous)
    Dim connect As Variant      'Chemin et nom de la BDD Access
    Dim reqconv As Variant      'Emplacement de la variable recherchée
    Dim dimconv As Variant      'Dimension de la table/requête selectionnée
    Dim rq As Variant           'table/requête selectionnée
    Dim cmdsql As Variant       'Commande SQL
     
    Application.ScreenUpdating = False
     
     '                                                        **
     '                                                    **********
     '                                                        **
    '----------------------------------------------------PARAMETRAGES------------------------------------------------------
     
    Nomconnect = "DataTest - CONDITIONS"
    Piloteodc = "\\mg21\ODC\" & Nomconnect & ".odc"
    connect = "\\mg21\DataTest.accdb"
    reqconv = ActiveWorkbook.Worksheets("CONTRAT").Range("C3").Value
    dimconv = "CONV"
    rq = "CONDITIONS"
    cmdsql = "SELECT * FROM " & rq & " WHERE " & rq & "." & dimconv & " = (""" & reqconv & """)" 
     
     '                                                        **
     '                                                    **********
     '                                                        **
    '-------------------------------------------------------REQUETE----------------------------------------------------------
     
    ActiveWorkbook.Connections(Nomconnect).Delete
     
    ActiveWorkbook.Connections.AddFromFile Piloteodc
     
        With ActiveWorkbook.Connections(Nomconnect).OLEDBConnection
            .CommandText = Array(cmdsql)
            .ServerCredentialsMethod = xlCredentialsMethodIntegrated
        End With
     
        ActiveWorkbook.Connections(Nomconnect).Refresh
     
     
    '-------------------------------------------------------FIN--------------------------------------------------------------
     
        Application.ScreenUpdating = True
     
    End Sub

  11. #11
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 73
    Points : 38
    Points
    38
    Par défaut
    Dernière question :
    Lorsqu'un utilisateur obtient ce type de message; quelle est la raison du symptome?

    Nom : err.jpg
Affichages : 766
Taille : 25,4 Ko


    Merci pour vos réponses!

  12. #12
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Développeur VBA/C#/VB.Net/Power Platform
    Inscrit en
    Juillet 2007
    Messages
    14 594
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur VBA/C#/VB.Net/Power Platform
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 594
    Points : 34 263
    Points
    34 263
    Par défaut
    Salut,

    je pencherais pour un mot de passe incorrect.
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  13. #13
    Invité
    Invité(e)
    Par défaut
    bonjour,
    personnellement j'opterais pour un connecteur ODBC (on la détermine dans le gestionnaire ODBC{panneau de configuration} de Windows) via un dsn fichier sur le serveur et je ne modifiais pas ma connexion dans Excel!

    je vérifiais le mode exclusif de ma base Access et tout le toutim!

    attention voir dans le option Excel si un connexion interne à XLS ne verrouille quand même pas le base de données ça je suis moins compétant!
    Dernière modification par Invité ; 30/09/2016 à 10h51.

  14. #14
    Expert éminent sénior
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Points : 18 677
    Points
    18 677
    Par défaut



    Salut Robert !

    Re-bienvenue sur ce forum !

    Tu es bien allégé en étoiles mais cela ne change rien à la qualité de tes interventions !
    C'est parce que la vitesse de la lumière est plus rapide que celle du son que tant de gens paressent brillants avant d'avoir l'air con ! (Thomas Boishardy)

  15. #15
    Expert confirmé
    Homme Profil pro
    PAO
    Inscrit en
    Octobre 2014
    Messages
    2 576
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : PAO
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Octobre 2014
    Messages : 2 576
    Points : 4 174
    Points
    4 174
    Par défaut
    Robert top ton nouveau pseudo
    Cordialement
    Ryu

    La connaissance s’acquiert par l’expérience, tout le reste n’est que de l’information. – Albert Einstein

    Pensez à la Balise [ CODE][/CODE ] - à utiliser via le bouton # => Exemple

    Une fois votre problème solutionné pensez à mettre en n'oubliant pas d'indiquer qu'elle est la solution finale choisie

  16. #16
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 73
    Points : 38
    Points
    38
    Par défaut
    ok merci pour vos réponses; je vais enquêter sur les bases de vos réponses

Discussions similaires

  1. Problème de mot de passe : Connexion Access
    Par digital prophecy dans le forum Bases de données
    Réponses: 12
    Dernier message: 13/06/2012, 10h23
  2. Probleme de connexion Access - SQL Server
    Par 24 faubourg dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 07/12/2005, 22h24
  3. Comment désactiver la fermeture d'access ?
    Par Elois dans le forum Access
    Réponses: 3
    Dernier message: 30/09/2005, 11h39
  4. Réponses: 3
    Dernier message: 28/09/2004, 16h39
  5. problèmede connexion à Access
    Par boucher_emilie dans le forum ASP
    Réponses: 29
    Dernier message: 01/07/2004, 14h48

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