热情软件屋

 

能否使用ADO2.5或SQL语言创建和修改*.dbf 表


编号:QA004514
建立日期: 2002年1月2日 最后修改日期:2002年3月15日
所属类别:

tnkmyun:
    操作系统:WIN98
    编程工具:VC6++
    问题:本人用ADO2.5编程,储取资料使用 *.dbf 数据格式,
     1.能否使用ADO2.5或SQL语言创建和修改*.dbf 表 ?
     2.当删除某条记录后,能否彻底从资料库中消除 ?
    水平:中级

回答:

    ADO不支持数据库定义及相应SQL,可以用DAO或ADOX。
    但自从OFFICE2000自动更新ODBC3.5为ODBC4.0后,对FOXBASE的.DBF改为有限支持(只读),建议改用VISUAL FOXPRO的.DBF,否则只能参照微软的方法恢复ODBC3.5(以后还会被更新成ODBC4.0),或者拷贝ODBC3.5的联结库至你的程序路径,并为每一个可执行文件制作DUMMY文件。
    
    guang问:
    我知道ADOX,但应该如何在VC++中用ADOX呢?谢谢!
    李海:下面是一个使用ADOX建立表的例子。在MSDN Library中使用ADOX作为关键词搜索,你可以找到更多的例子:
    // BeginCreateTableCpp
    #import "c:\Program Files\Common Files\system\ado\msadox.dll" \
     no_namespace
    
    #include "iostream.h"
    #include "stdio.h"
    #include "conio.h"
    
    //Function declarations
    inline void TESTHR(HRESULT x) {if FAILED(x) _com_issue_error(x);};
    void CreateTableX(void);
    
    //////////////////////////////////////////////////////////
    // //
    // Main Function //
    // //
    //////////////////////////////////////////////////////////
    void main()
    {
     if(FAILED(::CoInitialize(NULL)))
     return;
    
     CreateTableX();
    
     ::CoUninitialize();
    }
    
    //////////////////////////////////////////////////////////
    // //
    // CreateTableX Function //
    // //
    //////////////////////////////////////////////////////////
    void CreateTableX()
    {
     HRESULT hr = S_OK;
    
     // Define ADOX object pointers.
     // Initialize pointers on define.
     // These are in the ADOX:: namespace.
     _CatalogPtr m_pCatalog = NULL;
     _TablePtr m_pTable = NULL;
    
     try
     {
     TESTHR(hr = m_pCatalog.CreateInstance(__uuidof(Catalog)));
    
     //Open the catalog
     m_pCatalog->PutActiveConnection(
     "Provider=Microsoft.Jet.OLEDB.4.0;" \
     "data source=c:\\Program Files\\Microsoft Office"
     "\\Office\\Samples\\Northwind.mdb;");
    
     TESTHR(hr = m_pTable.CreateInstance(__uuidof(Table)));
     m_pTable->PutName("MyTable");
     m_pTable->Columns->Append("Column1",adInteger,0);
     m_pTable->Columns->Append("Column2",adInteger,0);
     m_pTable->Columns->Append("Column3",adVarWChar,50);
     m_pCatalog->Tables->Append(
     _variant_t((IDispatch *)m_pTable));
    
     //Delete the table
     m_pCatalog->Tables->Delete("MyTable");
     }
    
     catch(_com_error &e)
     {
     // Notify the user of errors if any.
     _bstr_t bstrSource(e.Source());
     _bstr_t bstrDescription(e.Description());
    
     printf("\n\tSource : %s \n\tdescription : %s \n ",
     (LPCSTR)bstrSource,(LPCSTR)bstrDescription);
     }
    
     catch(...)
     {
     cout << "Error occured in include files...."<< endl;
     }
    }
    // EndCreateTableCpp

此问题由songchuanzhen回答。

 
把这个问题推荐给朋友
   
   
您的意见类别
您的名字
您的电子邮件
您的建议(请尽可能详细)
 
 

版权所有 1997-2008 热情软件屋
如果您有任何建议和意见, 请给我发个电子邮件 askpro@china-askpro.com
Web Designed by ZebraStudio