DOCUMENT:Q184511 17-JUL-2001 [visualc] TITLE :DOC: Append Instructions for DAO TableDef Incorrect PRODUCT :Microsoft C Compiler PROD/VER:WINNT:4.0 OPER/SYS: KEYWORDS:kbdocfix kbdocerrkbfaq ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - The Microsoft Foundation Classes (MFC) - Microsoft Visual C++, version 4.0 ------------------------------------------------------------------------------- SUMMARY ======= In the "DAO TableDef: Using TableDefs" section appearing under Visual C++ Books MFC 4.0 Programming with MFC Encyclopedia DAO TableDef of the Visual C++ 4.0 documentation, the following set of instructions are given on how to create a TableDef: To create a tabledef. 1. Construct a CDaoTableDef object, supplying a pointer to the CDaoDatabase object to which the tabledef will belong. 2. Call the tabledef object's Create member function. 3. Set any of the tabledef object's properties that you want. Call the SetAttributes, SetConnect, SetName, SetSourceTableName, SetValidationRule, or SetValidationText member functions. 4. Call the tabledef object's Append member function to save the tabledef in the database's TableDefs collection. You can append before or after creating fields, as described in the next step. 5. Add fields to the tabledef by calling its CreateField member function for each field. (You can not modify the schema of an attached table, so this step applies only to local base tables and tables in external data sources that you open directly.) 6. Optionally add indexes to the tabledef by calling its CreateIndex member function for each index. The fourth step is out of sequence and contains incorrect information. MORE INFORMATION ================ Step 4 above states that "You can append before or after creating fields, as described in the next step." This is incorrect. Also, the TableDef's Append member should be called after the procedures mentioned in steps 5 and 6. The above instructions should read as follows: To create a tabledef. 1. Construct a CDaoTableDef object, supplying a pointer to the CDaoDatabase object to which the tabledef will belong. 2. Call the tabledef object's Create member function. 3. Set any of the tabledef object's properties that you want. Call the SetAttributes, SetConnect, SetName, SetSourceTableName, SetValidationRule, or SetValidationText member functions. 4. Add fields to the TableDef by calling its CreateField member function for each field. (You can not modify the schema of an attached table, so this step applies only to local base tables and tables in external data sources that you can open directly). 5. Optionally add indexes to the tabledef by calling its CreateIndex member function for each index. 6. Call the TableDef object's Append member function to save the TableDef in the database's TableDefs collection. NOTE: This documentation error is fixed in the Visual C++ 5.0 documentation. Additional query words: VC++ ====================================================================== Keywords : kbdocfix kbdocerr kbfaq Technology : kbVCsearch kbVC400 kbAudDeveloper kbMFC Version : WINNT:4.0 Hardware : x86 Issue type : kbhowto Solution Type : kbnofix ============================================================================= 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.