1. 代码说明 (1)在 stdafx.h 加入如下代码引入 ADO 库定义文件, #import "c:/program files/common files/system/ado/msado15.dll" / no_namespace / rename ("EOF", "adoEOF") (2)初始化COM库,在BOOL CGetFieldNameApp::InitInstance()中添加AfxOleInit(); (3)在类 CgetFieldNameDlg 中添加两个用于打开数据库连接和打开记录集的变量; _ConnectionPtr m_pConnection; _RecordsetPtr m_pRecordset; (4) 在CgetFieldNameDlg的构造函数中添加数据库连接和记录集初始化代码;m_pConnection.CreateInstance(__uuidof(Connection)); try { m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D://FTI.mdb", "", "", adModeUnknown ); } catch(_com_error e) { AfxMessageBox("数据库连接失败!"); } m_pRecordset.CreateInstance(__uuidof(Recordset)); (5) 给Listbox控件添加控件变量m_FieldsList; (6) 在按钮的单击事件中添加相应代码;_bstr_t mStrSQL; CString strColName; BSTR bstrColName; long ColCount,i; Field * field = NULL; HRESULT hr; Fields * fields = NULL; LPCTSTR nameField; //打开记录集,得到字段名,并将字段名信息添加到ListBox中 mStrSQL = "SELECT * FROM Images"; m_pRecordset->Open(mStrSQL, m_pConnection.GetInterfacePtr(), adOpenDynamic, adLockOptimistic, adCmdText); hr = m_pRecordset->get_Fields (&fields); //得到记录集的字段集和 if(SUCCEEDED(hr)) fields->get_Count(&ColCount); //得到记录集的字段集合中的字段的总个数 for(i=0;i { fields->Item[i]->get_Name(&bstrColName); //得到记录集//中的字段名 strColName=bstrColName; nameField = strColName; m_FieldsList.AddString(nameField); } if(SUCCEEDED(hr)) fields->Release();//释放指针 |
|