ADO开发中如何得到表格字段名

来源:互联网 发布:传奇永恒cpu优化 编辑:程序博客网 时间:2024/05/19 09:37
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();//释放指针
原创粉丝点击