中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Visual C++ > 数据库操作
ADO开发中如何得到表格字段名
作者:未知 时间:2005-07-20 14:19 出处:VC知识库 责编:chinaitpower
              摘要:ADO开发中如何得到表格字段名

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

作者:杨桂文

下载本文示例源代码

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

•  新建一 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;i<ColCount;i++)			
{			
	fields->Item[i]->get_Name(&bstrColName);	//得到记录集//中的字段名
	strColName=bstrColName;	
	nameField = strColName;
	m_FieldsList.AddString(nameField);
}		

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

(全文完)
关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有