Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1826053
  • 博文数量: 950
  • 博客积分: 10000
  • 博客等级: 上将
  • 技术积分: 13070
  • 用 户 组: 普通用户
  • 注册时间: 2008-08-04 09:23
文章分类

全部博文(950)

文章存档

2011年(1)

2008年(949)

我的朋友

分类: C/C++

2008-08-04 09:32:56

下载本文示例代码
下载本文示例源代码

在数据库的开发过程中,常用的操作不仅有添加、修改、删除记录,还有对字段的操作,而获得字段名就是其中的一种。获得字段名之前必须先与数据库建立连接,再打开相应的表,再得到表的字段集,下面以一程序为例,说明如何得到字段名。

• 新建一 VC MFCAppWizard(exe)工程,类型为Dialog based;

• 添加一按钮名为“显示字段”,添加一 Listbox控件;

• 创建 Access数据库FTI.mdb;

• 运行效果如图所示:



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;iItem[i]->get_Name(&bstrColName);	//得到记录集//中的字段名

	strColName=bstrColName;	

	nameField = strColName;

	m_FieldsList.AddString(nameField);

}		



if(SUCCEEDED(hr))

	fields->Release();//释放指针


(全文完) 下载本文示例代码
阅读(227) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~