ACC : Nombre d'enregistrements incorrect avec les tableaux multi-utilisateur

Traductions disponibles Traductions disponibles
Numéro d'article: 105129 - Voir les produits auxquels s'applique cet article
Cet article a été archivé. Il est proposé « en l'état » et ne sera plus mis à jour.
Modéré : Nécessite des compétences de l'interopérabilité, de codage et de macro de base.
Agrandir tout | Réduire tout

Symptômes

Lorsque plusieurs utilisateurs d'accéder à la même table et supprimez des enregistrements, le nombre d'enregistrements ne reflète pas toujours avec précision le nombre réel d'enregistrements de la table.

Par exemple, supposons que deux utilisateurs différents d'accéder à la même table. Utilisateur 1 imprime le nombre d'enregistrements dans la table, supprime le dernier enregistrement et ferme ensuite la table. Ensuite, l'utilisateur 2 ouvre la même table et imprime le nombre d'enregistrements dans la table. Nombre d'enregistrements peut être le même pour les deux utilisateurs même si le nombre d'enregistrements pour l'utilisateur 2 doit être un inférieur à pour l'utilisateur 1.

Cause

Pages ne sont pas supprimés du cache de page de fermeture d'une table. Lorsqu'une table est rouvert, il est possible pour les pages obsolètes être présent dans le cache de page, ce qui peut donner lieu à nombre d'enregistrements inexactes.

Résolution

Bien que la propriété RecordCount d'un tableau retourne le nombre approximatif d'enregistrements dans la table, la propriété RecordCount d'une capture instantanée renvoie le nombre réel d'enregistrements dans la capture instantanée. Vous pouvez utiliser la fonction définie par l'utilisateur exemple suivante pour renvoyer le nombre d'enregistrements d'une table en créant un instantané de la table :
   Function ReturnRecordCount (mytablename As String)

      'Define variables.
      Dim mytable As Table, mydb As Database
      Dim mysnapshot As Snapshot

      'Initialize variables.
      Set mydb = CurrentDB()
      Set mytable = mydb.OpenTable(mytablename)
      'Create a snapshot based on the table.
      Set mysnapshot = mytable.CreateSnapshot()

      mysnapshot.MoveLast
      myrecordcount = mysnapshot.recordcount

      mysnapshot.Close
      mytable.Close
      mydb.Close

      ReturnRecordCount = myrecordcount

   End Function
				

Références

Pour plus d'informations sur les captures instantanées, recherchez «instantané» et «Objet capture instantanée--résumé» à l'aide du menu aide de Microsoft Access.

Pour plus d'informations sur la propriété RecordCount, recherchez «RecordCount» et «Propriété RecordCount» à l'aide du menu aide de Microsoft Access.

Propriétés

Numéro d'article: 105129 - Dernière mise à jour: mardi 11 février 2014 - Version: 2.2
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft Access 1.0 Standard
  • Microsoft Access 1.1 Standard
  • Microsoft Access 2.0 Standard
  • Microsoft Access 95 Standard
Mots-clés : 
kbnosurvey kbarchive kbmt kbprb kbprogramming kbusage KB105129 KbMtfr
Traduction automatique
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: 105129
L'INFORMATION CONTENUE DANS CE DOCUMENT EST FOURNIE PAR MICROSOFT SANS GARANTIE D'AUCUNE SORTE, EXPLICITE OU IMPLICITE. L'UTILISATEUR ASSUME LE RISQUE DE L'UTILISATION DU CONTENU DE CE DOCUMENT. CE DOCUMENT NE PEUT ETRE REVENDU OU CEDE EN ECHANGE D'UN QUELCONQUE PROFIT.

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com