Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

LIAISON VB.NET ET ACCESS


Information sur la source

Catégorie :Trucs & Astuces Source .NET ( DotNet ) Niveau : Débutant Date de création : 16/07/2004 Date de mise à jour : 19/07/2004 16:19:29 Vu : 12 924

Note :
6 / 10 - par 2 personnes
6,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (11)
Ajouter un commentaire et/ou une note

Description

je suis parti d'un problème, ADO.Net se connecte a une base de donnée, mais ferme tout de suite la connection après. Donc il faut se reconnecter dessus a chaque fois. Le problème viens du fait, quand on a beaucoup de connection a faire, ça ralentie beaucoup le code, donc voici une astuce

Faite une référence a Access
Crée un module dans Access, ex: Module1

créer une procédure dedans, ex: Test

ensuite, de VB.Net appeller la procédure qui se trouve dans Access et le tour est joué.

Biens sur, si c'était que ça, ça vaudra pas la peine de dire juste ça. Donc voici un module en VB.Net qui fait tout pour vous :-)
 

Source

  • Module Access2
  • Dim soft As Access.Application
  • Dim ouvert As Boolean = False
  • Public Sub impression(ByVal nom As String, Optional ByVal Acview As Access.AcFormView = Access.AcFormView.acPreview, Optional ByVal filtre As String = "", Optional ByVal where As String = "")
  • ouvrirAccess()
  • Try
  • soft.DoCmd.OpenReport(nom, Acview, filtre, where)
  • soft.DoCmd.Maximize()
  • Catch
  • End Try
  • End Sub
  • Public Sub executerCode(ByVal code As String, ByVal arg1 As String)
  • ouvrirAccess()
  • Try
  • soft.Run(code, arg1)
  • Catch
  • End Try
  • End Sub
  • Public Sub executerCode(ByVal code As String, ByVal arg1 As String, ByVal arg2 As String)
  • ouvrirAccess()
  • Try
  • soft.Run(code, arg1, arg2)
  • Catch
  • End Try
  • End Sub
  • Public Sub executerCode(ByVal code As String)
  • ouvrirAccess()
  • soft.Run(code)
  • End Sub
  • Public Sub fermeture()
  • On Error Resume Next
  • soft.CloseCurrentDatabase()
  • soft.Quit()
  • soft = Nothing
  • End Sub
  • Public Sub ouvrirAccess()
  • Dim temp As String
  • Try
  • temp = soft.CurrentDb.Version
  • Catch
  • If Not ouvert Then
  • soft = New Access.Application
  • soft.Visible = True
  • ouvert = True
  • End If
  • soft.OpenCurrentDatabase("C:\projet.mdb")
  • End Try
  • End Sub
  • End Module
Module Access2
    Dim soft As Access.Application
    Dim ouvert As Boolean = False

    Public Sub impression(ByVal nom As String, Optional ByVal Acview As Access.AcFormView = Access.AcFormView.acPreview, Optional ByVal filtre As String = "", Optional ByVal where As String = "")
        ouvrirAccess()
        Try
            soft.DoCmd.OpenReport(nom, Acview, filtre, where)
            soft.DoCmd.Maximize()
        Catch
        End Try
    End Sub

    Public Sub executerCode(ByVal code As String, ByVal arg1 As String)
        ouvrirAccess()
        Try
            soft.Run(code, arg1)
        Catch
        End Try
    End Sub

    Public Sub executerCode(ByVal code As String, ByVal arg1 As String, ByVal arg2 As String)
        ouvrirAccess()
        Try
            soft.Run(code, arg1, arg2)
        Catch
        End Try
    End Sub

    Public Sub executerCode(ByVal code As String)
        ouvrirAccess()
        soft.Run(code)
    End Sub

    Public Sub fermeture()
        On Error Resume Next
        soft.CloseCurrentDatabase()
        soft.Quit()
        soft = Nothing
    End Sub

    Public Sub ouvrirAccess()
        Dim temp As String
        Try
            temp = soft.CurrentDb.Version
        Catch
            If Not ouvert Then
                soft = New Access.Application
                soft.Visible = True
                ouvert = True
            End If
            soft.OpenCurrentDatabase("C:\projet.mdb")
        End Try
    End Sub
End Module

Conclusion

attention, si vous voulez appeller la procédure Test, faut faire executerCode("Test") et pas executerCode("Module1.Test")


Attention 2: les type interger passe sasn problème, malgré le fait qu'un integer .Net est 32 bit et un integer Access est 16 bit. par contre, un type date passe pas :-(. Pour passer une date, la procédure dans Access va devoir recevoir un string et une conversion automatique va se faire entre la date .Net vers un string Access. Ensuite si vous voulez travailler avec une date sous access, envoyer la dans un variable de type date pis mettez lui un format

ex: sous Access pour recevoir un format Date de .Net
Public Sub GroupeHoraireTest(test As String)
    Dim temp As Date
    temp = Format(test, "yyyy-mm-dd")
    MsgBox temp
End Sub
 

Historique

16 juillet 2004 19:51:31 :
Corrections de 2 fautes
19 juillet 2004 16:19:29 :
Attention2

Commentaires et avis

signaler à un administrateur
Commentaire de Scalpweb le 17/07/2004 00:02:56

Il manque un petit zip...

signaler à un administrateur
Commentaire de Cameleon69 le 17/07/2004 09:44:55

Oui un zip serait bien.

signaler à un administrateur
Commentaire de lumesh le 17/07/2004 10:00:41

en fait une classe aurait ete bcp mieux !
pour la simple raison c'est que tu aurais pu utiliser la meme classe pour gérer plusieurs connexions simultanée, deplus tant que celle ci nest pas fermée la connexion serait restée ...

enfin bon .. apres cest chacun ses gouts bien sur

signaler à un administrateur
Commentaire de dragon le 19/07/2004 13:23:05

pour le zip, regarde la catégorie de la source, Astuce. pis c,est pas assez long comme code pour faire une source

et pour la class, je susi vraiment pas d'accord, puisqu'on doit créer une variable de la class, un module, partout dans le programme on peut faire Access2.executerCode(....)

signaler à un administrateur
Commentaire de DocPhiphi le 15/02/2005 21:34:46

Heu, ça marche comment ??
parceque 3 sub avec le même nom (executerCode), je vois mal comment ça se débrouille....
Et puis, ce prog est bon pour quelqqu'un qui a Access sur son poste. Et quand on ne l'a pas ?????

signaler à un administrateur
Commentaire de undergroundover le 11/12/2006 09:43:52

DocPhiphi, c'est possible d'avoir 3 subs avec le meme nom, ca s'appelle la surchage de fonction... ;)

signaler à un administrateur
Commentaire de winni le 02/05/2007 18:35:06

Comment as tu fait pour declarer l'application Access
Dim soft As Access.Application

Faut il un truc du genre imports. ?

signaler à un administrateur
Commentaire de dragon le 02/05/2007 19:49:02

oui, tu dois faire une référence

signaler à un administrateur
Commentaire de winni le 03/05/2007 07:32:56

laquelle ?

signaler à un administrateur
Commentaire de kamal2007 le 25/05/2007 00:18:49

MERCI POUR  l'aide

signaler à un administrateur
Commentaire de zouzouzizou le 18/02/2008 12:21:23

une demonstration serait bien utile

Ajouter un commentaire



Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Comparez les prix Nouvelle version

Photothèque Nouveau !



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,328 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.