Vous êtes actuellement hors ligne, en attente de reconnexion à Internet.

Comment faire pour compacter la base de données Microsoft Access via ADO

IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d’articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d’avoir accès, dans votre propre langue, à l’ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s’exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s’efforce aussi continuellement de faire évoluer son système de traduction automatique.

La version anglaise de cet article est la suivante: 230501
Exclusion de responsabilité concernant les contenus obsolètes dans la Base de connaissances
Cet article concerne des produits pour lesquels Microsoft n'offre plus de support. Il est par conséquent fourni « en l'état » et ne sera plus mis à jour.
Résumé
Bien que la spécification ADO ne fournit pas d'objets pour compacter des bases de données Microsoft Access, cette fonctionnalité peut être obtenue en utilisant l'extension d'ADO : fournisseur OLE DB Microsoft Jet et Replication Objects (JRO). Cette fonctionnalité a été implémentée pour la première fois dans le fournisseur JET OLE DB version 4.0 (Msjetoledb40.dll) et JRO 2.1 (Msjro.dll). Ces fichiers DLL sont disponibles après l'installation de MDAC 2.1. Vous pouvez télécharger la dernière version de MDAC à partir du site Web suivant :
Plus d'informations
Pour compacter une base de données Access à l'aide d'ADO, MDAC 2.1 ou ultérieure doit être installé correctement sur l'ordinateur. Voici les principales étapes pour compacter une base de données Microsoft Access à l'aide de Visual Basic et Visual C++ :

Visual Basic : Le compactage d'une base de données Access via ADO

  1. Dans l'IDE de Visual Basic, dans le menu projets , cliquez sur références.
  2. Ajouter Microsoft Jet and Replication Objects X.X library, où (X.X est supérieur ou égal à 2.1).
  3. Pour Visual Basic, remplaçant les chemins des base de données source et destination de données si nécessaire, ajoutez les lignes de code suivantes :
    Dim jro As jro.JetEngineSet jro = New jro.JetEnginejro.CompactDatabase "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\nwind2.mdb;Jet OLEDB:Database Password=test", _ "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\abbc2.mdb;Jet OLEDB:Engine Type=4;Jet OLEDB:Database Password=test"					
Remarque : Dans DAO 3.60, la méthode RepairDatabase n'est plus disponible. Le code ci-dessus illustre l'utilisation de la méthode CompactDatabase. Cette méthode remplace la méthode DAO 3.5 RepairDatabase.

Visual C++: Compactage d'une base de données Access via ADO

  1. En plus de # import, le Msado15.dll (MDAC2.1), ajoutez l'instruction # import suivante pour générer les classes wrapper pour JRO pour vos classes .cpp (Sinon, vous pouvez générer les classes wrapper plus efficacement en utilisant les attributs no_implementation et implementation_only de l'instruction préprocesseur # import) :
    #import "C:\PROGRAM FILES\COMMON FILES\System\ado\MSJRO.DLL" no_namespace 					
  2. Ajoutez le code suivant (en spécifiant vos propres chemins de base de données source et destination) dans le fichier .cpp dans lequel vous souhaitez compacter la base de données :
    ...try{   IJetEnginePtr jet(__uuidof(JetEngine));  jet->CompactDatabase( "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\nwind2.mdb;Jet OLEDB:Database Password=test", "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\abbc.mdb;" \ "Jet OLEDB:Engine Type=4;Jet OLEDB:Database Password=test");}catch(_com_error &e) {          ::MessageBox(NULL, (LPCTSTR)e.Description( ), "", MB_OK) ;    }					
Remarque : Le Type de OLEDB:Engine Jet = 4 est uniquement pour les fichiers de Jet 3.x au format MDB. Si cette valeur est omises, la base de données est automatiquement mis à niveau vers la version 4.0 (Jet OLEDB:Engine Type = 5). Consultez le tableau suivant pour les valeurs appropriées pour le Type de OLEDB:Engine Jet :
Type de OLEDB:Engine JetJet x.x des fichiers au Format MDB
1JET10
2JET11
3JET2X
4JET3X
5JET4X
Références
Pour plus d'informations, reportez-vous aux rubriques ci-dessousarticle de la Base de connaissances Microsoft :
230496 Compactage de base données Microsoft Access via OLE DB
Reindex CompactDatabase RepairDatabase

Avertissement : cet article a été traduit automatiquement

Propriétés

ID d'article : 230501 - Dernière mise à jour : 05/16/2012 07:07:00 - Révision : 1.0

  • kbhowto kbjet kbprovider kbmt KB230501 KbMtfr
Commentaires
;m.name='ms.dqp0';m.content='true';document.getElementsByTagName('head')[0].appendChild(m);" onload="var m=document.createElement('meta');m.name='ms.dqp0';m.content='false';document.getElementsByTagName('head')[0].appendChild(m);" src="http://c1.microsoft.com/c.gif?"> uage(language);" class="ng-binding" id="language-es-py">Paraguay - Español
Venezuela - Español
="var m=document.createElement('meta');m.name='ms.dqp0';m.content='false';document.getElementsByTagName('head')[0].appendChild(m);" src="http://c1.microsoft.com/c.gif?"> + (window.location.protocol) + "//c.microsoft.com/ms.js'><\/script>");