DOCUMENT:Q162958 30-JUL-2001 [visualc] TITLE :FIX: Format of the Password Parameter for CompactDatabase PRODUCT :Microsoft C Compiler PROD/VER:4.0 4.1 4.2 5.0 OPER/SYS: KEYWORDS:kbcode kberrmsg kbdocerr kbDAOsearch kbDatabase kbMFC kbDocs kbVC kbVC400bug kbVC410 kb ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - The Microsoft Foundation Classes (MFC), included with: - Microsoft Visual C++, 32-bit Editions, versions 4.0, 4.1 - Microsoft Visual C++, 32-bit Enterprise Edition, version 4.2 - Microsoft Visual C++, 32-bit Professional Edition, version 4.2 - Microsoft Visual C++, 32-bit Enterprise Edition, version 5.0 - Microsoft Visual C++, 32-bit Professional Edition, version 5.0 ------------------------------------------------------------------------------- SUMMARY ======= The documentation for the CDaoWorkspace::CompactDatabase function does not specify the format of the password parameter. The password must be in the following format: ";PWD=password". If the password is not in the correct format, you may see the following error: Can't find installable ISAM MORE INFORMATION ================ The documentation for the CDaoWorkspace::CompactDatabase function gives the following information about compacting a password-protected database: static void PASCAL CompactDatabase( LPCTSTR lpszSrcName, LPCTSTR lpszDestName, LPCTSTR lpszLocale, int nOptions, LPCTSTR lpszPassword ); Parameters lpszPassword A password, used when you want to compact a password-protected database. Note that if you use the version of CompactDatabase that takes a password, you must supply all parameters. There is no information about the format of the password parameter. However, the documentation for the DBEngine.CompactDatabase function has the following information: Syntax DBEngine.CompactDatabase olddb, newdb [, locale [, options [, ;pwd=password]]] Part Description password An optional string argument containing a password, if the database is password protected. The string ";pwd=" must precede the actual password. Sample Code ----------- /* Compile options needed: none */ /* The following code will compress the database C:\DB1.MDB, which has * a password of "MyPassword" */ try { CDaoWorkspace::CompactDatabase( _T( "C:\\DB1.MDB" ), _T( "C:\\DB2.MDB" ), dbLangGeneral, dbVersion30, _T( ";PWD=MyPassword" ) ); } catch( CDaoException* e ) { AfxMessageBox( e->m_pErrorInfo->m_strDescription ); e->Delete(); } STATUS ====== This problem was corrected in the documentation for Visual C++, version 6.0. REFERENCES ========== Visual C++ Books Online: CDaoWorkspace::CompactDatabase Visual C++ Books Online: DBEngine.CompactDatabase Additional query words: Access Jet ====================================================================== Keywords : kbcode kberrmsg kbdocerr kbDAOsearch kbDatabase kbMFC kbDocs kbVC kbVC400bug kbVC410 kbVC420bug kbVC500bug kbVC600fix Technology : kbAudDeveloper kbMFC Version : 4.0 4.1 4.2 5.0 Issue type : kbbug Solution Type : kbfix ============================================================================= THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY. Copyright Microsoft Corporation 2001.