Defragment and compact database to improve performance in Microsoft Access
For a Microsoft Access 2000 version of this article, see 209769.
DefragmentingA disk defragmenter will place all files, including the database file into contiguous clusters on a hard disk, making file access faster. With the exception of the Microsoft Windows NT operating system, if you do not defragment your hard disk, the operating system may have to go to several physical locations on the disk to retrieve the database file, making file access slower.
CompactingRunning the Compact and Repair Database utility within Microsoft Access can also improve the performance of the database. This utility makes a copy of the database file and, if it is fragmented, rearranges how the database file is stored on disk. When completed, the compacted database has reclaimed wasted space, and is usually smaller than the original. By compacting the database frequently, optimal performance of the database application is ensured, and page corruptions due to hardware problems, power failures or surges, and so on are resolved.
If a primary key exists in the table, compacting restores table records into their primary key order. This provides the equivalent of Non-maintained Clustered Indexes, and makes the read-ahead capabilities of the Microsoft Jet database engine much more efficient.
Compacting also updates the table statistics within the database that are used as Jet optimizes queries. These statistics can become outdated as data is added, manipulated, and deleted from the various tables. Query speed will be enhanced significantly, because they are now working with data that has been rewritten to the tables in contiguous pages. Scanning sequential pages is much faster than scanning fragmented pages. Queries are forced to recompile/optimize after each database compaction.
During compaction, you can use the original name for the compacted database file, or you can use a different name to create a separate file. If you use the same name and the database is compacted successfully, Microsoft Access automatically replaces the original file with the compacted version.
In Microsoft Access, you can set an option to automate this procedure. To do so, on the Tools menu, click Options, click the General tab, and the click to select the Compact on Close check box. This will automatically compact and repair the database as it is closed.
Limitations of Compacting
- For the Compact operation to succeed, you must have enough storage space on your hard disk for both the original and the compacted database.
- You cannot compact an open database. In a multiuser environment, the compact operation is not successful if another user has the database open.
Note In Microsoft Access, you can compact a database while it is open, as long as the database has been opened exclusively.
Defragment or Compact First?If you compact a database after running a defragmenter, you theoretically leave open disk space immediately after the .mdb or .accdb file on the disk, allowing the operating system to place any additional information in the succeeding physical clusters. This would be very fast. However, if you defragment after running Compact Database, your .mdb file may be placed on the first part of the disk followed by the rest of your files, with no open disk space until the end (the inside tracks) of the disk. This makes disk access somewhat slower.
Note The Compact on Close setting is not available in Access 97.
Article ID: 288631 - Last Review: 03/26/2007 23:16:21 - Revision: 5.1
- kbperformance kbhowto KB288631