MFC中用列表控件(CListCtrl)关联ODBC的方法

本人是MFC小白,自学VC不到一个月,不会VB和SQL,只会一点C++。
现在需要做一个窗体(该项目已经和数据库关联),窗体中增加一个一个列表控件,在列表控件中能显示关联的access数据库。
跪求方法,或者求教学视频或者参考书目之类的

这个问题不难的,肯定是已经有非常成熟的办法的,我给你转了一篇,希望对你有用。

1、先建立数据库(这里以一个PrintTest为数据源名来处理,该数据库包含一张表info,里面有四个字段,ID,NAME,GROUP,AGE,只是测试用因此随便列出几个字段,其中ID为数字类型,其余为文本,采用Access数据库来建立。方法就是添加一张表,然后分别对表中填充一些数据,这里就不再讲述!)
2、ODBC数据源与程序的连接
a.在stdafx.h文件的尾部添加#include "afxdb.h"
b.针对于整个工程的全局函数CDatabase db;
c.在APP文件的初始化进程中添加打开数据库的语句

CWinApp::InitInstance(); // 此句为系统自动生成的;

if ( ! db.IsOpen())
db.Open( " PrintTest; " );
else
AfxMessageBox( " 数据库连接失败! " );
AfxEnableControlContainer(); // 此句为系统自动生成的;

至此,与数据库的连接基本上完成了,也正是因为这个db.Open("PrintTest;");才有了这篇文章。
3、向记录集(CRecordset)填充数据,在这里我们必须要谈到(数据库和记录集对象之间的)记录字段交换 (RFX)。(大家可以在MSDN中查阅相关信息。)现在只将步骤做一个简述:
a.在“类视图”中添加类,然后选择“MFC ODBC 使用者”;
b.在向导中,数据源按钮后选择“机器数据源”选择我们设置的ODBC数据源,这里为PrintTest;确定;
c.在弹出的对话框中选择info表,确定;
d.修改类名,文件名(如果有必要的话),这里改为CInfoRS,InfoRS.h,InfoRS.cpp
e.注意下面的选择是“动态集”,确定。(警告关闭)
这时候你可以在类向导中看到添加的新类,CInfoRS
4、在初始化对话框的时候进行数据的读入。
值得注意的是:我们刚才定义的是全局的变量,但是定义的语句是在APP文件中写入的,因此在Dlg文件中调用的时候我们仍然需要去声明一下它是全局变量,也就是对Dlg来说,它是在外部已经定义过的变量。因此在Dlg.cpp的开头我们补充extern CDatabase db;
在BOOL CPrintListCtrlDlg::OnInitDialog()中添加

// TODO: 在此添加额外的初始化代码 // 注意找到该函数中的这句话,在其后添加以下代码
m_cList.SetExtendedStyle(LVS_EX_GRIDLINES); // 设置ListCtrl的风格
int nWidth = 110 ;
m_cList.InsertColumn( 0 , " 会员编号 " ,LVCFMT_LEFT,nWidth * 2 / 3 );
m_cList.InsertColumn( 1 , " 会员姓名 " ,LVCFMT_LEFT,nWidth);
m_cList.InsertColumn( 2 , " 会员组织 " ,LVCFMT_LEFT,nWidth * 3 / 2 );
m_cList.InsertColumn( 3 , " 年龄 " ,LVCFMT_LEFT,nWidth / 2 );
CInfoRS rs( & db);
UpdateList(rs);
在这个应用程序中同样要注意到,因为我们需要的是一张类似Access表的表格,而不是类似我的电脑的图标形式的风格,因此我们需要在添加的ListControl的时候,将其属性中的View设置为Report。
UpdateList(rs);是我们自己添加的一个函数,再此我再介绍一下使用类向导添加函数的方法。
在类视图中,右键,添加->添加函数,然后添加相关参数,比如返回值类型,参数类型等,记得添加参数的时候按“添加”将其添加到参数列表中。
下面列出UpdateList的代码:

void CPrintListCtrlDlg::UpdateList(CInfoRS & rs)
{
int i = 0 ;
CString strID;
rs.Open();
m_cList.DeleteAllItems();
while ( ! rs.IsEOF())
{
m_cList.InsertItem(i, "" );
strID.Format( " %d " ,rs.m_ID);
m_cList.SetItemText(i, 0 ,strID);
m_cList.SetItemText(i, 1 ,rs.m_NAME );
m_cList.SetItemText(i, 2 ,rs.m_GROUP);
m_cList.SetItemText(i, 3 ,rs.m_AGE);
rs.MoveNext();
i ++ ;
}
rs.Close();
} 至此这个程序基本上就编写完成了,但是使用Ctrl+F5调试的时候出现了错误。错误具体就不再描述,只告诉解决的方法。
1、一个是CInfoRS类中一句#error Security Issue: The connection string may contain a password
解决方法:注释掉
2、类型不匹配:
m_cList.SetItemText(i,1,rs.m_NAME );
m_cList.SetItemText(i,2,rs.m_GROUP);
m_cList.SetItemText(i,3,rs.m_AGE);
将提示rs.m_NAME,rs.m_GROUP,rs.m_AGE不能从“CStringW”转换为“LPCTSTR”
解决方法:在类视图中定位到CInfoRS,在其变量(蓝色方块后),随便点一个进入。按以下方法修改:
//将以下代码:
long m_ID;
CStringW m_NAME;
CStringW m_GROUP;
CStringW m_AGE;
//修改为:
long m_ID;
CString m_NAME;
CString m_GROUP;
CString m_AGE;
//即将这里的CStringW替换为CString
//其实可以注意到之前的一大段话:以下字符串类型(如果存在)反映数据库字段(ANSI 数据类型的 CStringA 和 Unicode数据类型的 CStringW)的实际数据类型。这是为防止 ODBC 驱动程序执行可能不必要的转换。如果希望,可以将这些成员更改为CString 类型,ODBC 驱动程序将执行所有必要的转换。(注意: 必须使用 3.5 版或更高版本的 ODBC 驱动程序以同时支持 Unicode 和这些转换)。
至此,编译通过。
但是,随后弹出错误:ODBC数据源不支持动态集
修正这个问题的方法有二:
一、在刚才添加的时候,将动态集(默认)改为快照,在这里,将不会出现错误。
二、令人庆幸的是我曾经做过一个例子,里面确实是使用动态集,但并没有出现这个错误,于是我找到了另一个程序,再次调试通过。于是就很是郁闷。于是用断点调试,最终确定问题是发生在rs.Open();的位置。
于是查找MSDN发现(For CRecordset, the default value is CRecordset::snapshot.翻译:对于CRecordset默认值类对象,默认值是 CRecordset::snapshot,也就是快照模式),而我们所用的是动态集的模式。这里可以将rs.Open();改为rs.Open(CRecordset::forwardOnly);再次编译就可以通过了。
另外可以将最初的db.Open("PrintTest;");改为db.OpenEx("DSN=PrintTest;");就可以解决问题了。这其中的奥妙就不是很清楚,只能当作经验来和大家分享一下。也希望有知道的人能够留言告诉我。谢谢先~!

以下将本示例的代码以及数据库打包供大家学习下载!
http://www.cppblog.com/Files/mymsdn/PrintListCtrl.rar
温馨提示:内容为网友见解,仅供参考
第1个回答  2013-04-30
应该是先从数据库获取数据然后把这些数据设置到对应的表格中吧

mfc 对话框从数据库获得数据怎么在单文档CListCtrl控件中显示
1.从简单易用角度讲,用Dialog比较好。单文档的话,楼主可能找不到吧控件拖到哪里去。而且单文档有框架类和视图类,要在视图类里改,不要在框架类里面改。2.Dialogue的话,看你的需要了。在controls框里面拖一个列表控件。然后用classwizard添加一个control型成员m_list。对控件的操作,可以通过操作这...

MFC中CListCtrl列表控件连接数据库不显示数据的问题
列表控件,你在设置文本之前,一定要先InsertItem(行号,_T("")),然后再SetItemText,不然是不会显示出来的。祝你成功。

求MFC编写的有关CListCtrl控件的简单实例。 发到我的邮箱284832431@qq.c...
通过调用int InsertItem( int nItem, LPCTSTR lpszItem );可以在列表控件中nItem指明位置插入一项,lpszItem为显示字符。除LVS_REPORT风格外其他三种风格都只需要直接调用 InsertItem就可以了,但如果使用报表风格就必须先设置列表控件中的列信息。通过调用int InsertColumn( int nCol, LPCTSTR lpszColumnHeadi...

MFC中的列表控件,当选择了多项时,如何对选中的数据进行操作?
假设列表控件对象为m_ListCtrl;POSITION pos=m_ListCtrl.GetFirstSelectedItemPosition()for(POSITION posTemp=pos;posTemp!=NULL;){ int ItemIndex=GetNextSelectedItem(posTemp);} 如果你选择了4项,则这个循环会进行4次,每一次就可以得到一个选择项的对应的索引,保存到ItemIndex中。

如何将SQL数据库查询的多条信息显示在MFC的列表控件中
你要是想用微软现成的控件,可以在MSDN中查找下这个ADODC的ActiveX控件,百度一下也可以查到好多的。控件是要方便些,但是缺乏灵活性;我们现在一般都用的ADO类库自己写相关的代码,在对话框上增加一个控件CListCtrl然后用它的成员函数把查询结果一条一条插入进去CListCtrl::InsertItem();CListCtrl::SetItem...

mfc实现可编辑的列表控件,输入功能,求助
int icrusel =m_listctrl->GetNextItem(-1,LVIS_SELECTED|LVNI_ALL);if (pLVKeyDow->wVKey == VK_UP && icrusel!=0){ m_listctrl->SetItemState(-1,0,LVIS_SELECTED);\/\/在此处进行需要的操作 m_listctrl->SetItemState(icrusel-1,LVIS_SELECTED,LVIS_SELECTED);\/\/在此处进行需要的操作 \/...

求助,vc&MFC对话框重绘,CListCtrl列表出错
构造函数 ClistCtrl 构造一个CListCtrl对象 Create 创建列表控件并将其附加给CListCtrl对象 属性 GetBkColor 获取列表视图控件的背景色 SetBkColor 设置列表视图控件的背景色 GetImageList 获取用于绘制列表视图项的图象列表的句柄 SetImageList 指定一个图象列表到列表视图控件 GetItemCount 获取列表视图控件中的项...

MFC中函数的重载问题
m_tree是什么控件,标准CListCtrl的话,没有四个参数的情况。主要是第一个参数没有是字符串的情况。int InsertItem( int nItem, LPCTSTR lpszItem, int nImage );第一个参数是插入的第几项,从零开始,比如从第一项插入,此参数为零,最末一项则是 (nMaxCount - 1).第二个是插入项的文本显示...

CListCtrl 和CListBox 是什么关系,怎么用啊,多谢大虾们帮忙啊
1、CListBox封装了列表框控件,用于列出一系列表项,可供单选、多选、扩展多选或不选。一个常见样式如左图所示。2、CListCtrl封装了列表控件,用于以多种格式显示一组信息,有大图标格式、小图标格式,列表格式和报表格式。Windows资源管理器主界面就是一种列表控件样式,如右图所示。(当然,不一定是...

列表控件(CListCtrl) 是否可自行增加项?? 在最后的一行是否 可自行添 ...
CListCtrl::InsertItem intInsertItem(constLVITEM*pItem);int InsertItem( int nItem, LPCTSTR lpszItem );int InsertItem( int nItem, LPCTSTR lpszItem, int nImage );int InsertItem( UINT nMask, int nItem, LPCTSTR lpszItem, UINT nState, UINT nStateMask, int nImage, LPARAM lParam );...

相似回答