ACC: Why Converting to 95/97 Results in Different Database Size (160125)
The information in this article applies to:
- Microsoft Access for Windows 95 7.0
- Microsoft Access 97
This article was previously published under Q160125 SUMMARY
This article explains why your Microsoft Access databases can change in
size when you convert them from an earlier version to Microsoft Access 7.0
or 97.
MORE INFORMATION
When you convert or open a Microsoft Access 1.x or 2.0 database in
Microsoft Access 7.0 or 97, Microsoft Access converts your Access Basic
code to Visual Basic for Applications code. This can change the size of
your database for the following reasons.
The MSysModules2 Table
Microsoft Access 97 creates and stores separate copies of your form
modules, report modules, and global modules in a system table called
MSysModules2 (or MSysModules in version 7.0). This table can double the
size of your modules, depending on the amount of code the database
contains. The table is created whether you convert your database or just
open it in Microsoft Access 7.0 or 97. If you open your Microsoft Access
1.x or 2.0 database in both Microsoft Access 7.0 and Microsoft Access 97,
the MSysModules and MSysModules2 tables are created, which can result in a
large increase in your database.
Microsoft Access 97 introduces a new feature called lightweight objects. A
lightweight object is one that does not have a code module attached to it,
so it does not require any space in the MSysModules2 table. If a form or
report in your Microsoft Access 1.x or 2.0 database does not contain any
Access Basic code, Microsoft Access 97 converts it to a lightweight object
when you convert your database. This can help to decrease the size of your
database. Note that lightweight objects are only created when you convert
your database, and not if you just open it in Microsoft Access 97.
Compiled Code
To improve performance, Microsoft Access 7.0 and 97 store Visual Basic for
Applications modules in a compiled state. Microsoft Access 1.x and 2.0
store Access Basic modules in an uncompiled state. This difference
increases the size of your converted database because the database contains
both the editable source code and the compiled code.
Microsoft Access 97 introduces a new feature called MDE files. An MDE file
is a database from which all editable source code has been removed and only
the compiled code remains. This results in a smaller database.
To find out more about how to use MDE files in Microsoft Access 97, search
the Help Index for "MDE files," or ask the Microsoft Access 97 Office
Assistant.
Compacting Your Database After Conversion
The conversion process itself causes your database to increase in size
because all of the database objects are modified. The same behavior occurs
when you delete records or modify the design of objects in your database.
To decrease the size of your database, you can run the Compact Database
command.
In Microsoft Access 97, the conversion utility compacts your database as
part of the process, which helps decrease the size of the database.
However, Microsoft Access 7.0 does not automatically compact your database
after it is converted; you must run the Compact Database command manually
to decrease the size of the converted database.
REFERENCES
For more information about converting a database, search the Help Index for
"converting databases," or ask the Microsoft Access 97 Office Assistant.
For more information about the Compact Database command, search the Help
Index for "compacting databases," or ask the Microsoft Access 97 Office
Assistant.
Modification Type: | Major | Last Reviewed: | 10/20/2003 |
---|
Keywords: | kbinfo kbusage KB160125 |
---|
|