264上位机VC MFC使用ODBC基于列表视图显示数据表全部记录
264上位机VC MFC使用ODBC基于列表视图显示数据表全部记录功能展示
使用列表视图来显示记录集数据界面会更友好编程也简单,还可以通过双击在界面上显示的记录条可以显示此条目是第几条记录等,我们当前例程就实现了利用列表视图为显示记录集数据的功能,效果如右图;
要点提示
1.这里要注意的是view类中记录集对象指针m_pSet的初始化,及赋值,在view的构造函数中初始化为NULL,在DOC类的OnNewDocument()被初始化为DOC类中的成员变量m_Set 有地址,这样在VIEW类的OnInitialUpdate()函数中显示数据库数据时才不会出错 实现功能 1.新建基于单文档的应用程序,记得视窗派生于CListView; 2.再用类向导新建一基于Crecordset的类CODBCSet; 在文档中类中添加此类的头文件#include “ODBCSet.h”及变量public:CODBCSetm_Set;在视窗中添加此类的头文件#include “ODBCSet.h”及变量public:CODBCSet *m_pSet; CListCtrl* m_List; 3.在视窗的构造函数中初始变化量,及析构函数中关闭记录集 - CGkbc8View::CGkbc8View()
- {
- m_pSet=NULL;
- m_List=&GetListCtrl();//获取列表视图控件
- m_dwDefaultStyle|=LVS_REPORT;//以报表的格式显示
- }
- CGkbc8View::~CGkbc8View()
- {
- if(m_pSet->IsOpen())
- m_pSet->Close();
- }
复制代码4.在文档类的OnNewDocument()函数中初始化视窗类的变量m_pSet - BOOL CGkbc8Doc::OnNewDocument()
- {
- if (!CDocument::OnNewDocument())
- return FALSE;
- // TODO: add reinitialization code here
- // (SDI documents will reuse this document)
- POSITION pos;
- pos=GetFirstViewPosition();
- CGkbc8View* pView =(CGkbc8View*)GetNextView(pos);
- pView->m_pSet=&m_Set;
- return TRUE;
- }
复制代码5.在视窗类的OnInitialUpdate()函数中实现数据表内容的全部显示 - void CGkbc8View::OnInitialUpdate()
- {
- CListView::OnInitialUpdate();
- //<>
- if(m_pSet==NULL)
- {
- AfxMessageBox("还没有对记录集进行初始化");
- return;
- }
- if(!m_pSet->IsOpen())
- {
- m_pSet->Open();//打开记录集
- }
- int i=0,j=0;
- CODBCFieldInfo DbFi;//存储记录集字段信息的结构体
- LV_COLUMN m_Lc;//存储列信息的结构体
- m_Lc.mask=LVCF_FMT|LVCF_WIDTH|LVCF_TEXT|LVCF_SUBITEM;//设置列属性
- //读取记录集的字段信息
- for(i=0;i<m_pSet->m_nFields;i++)
- {
- m_pSet->GetODBCFieldInfo(i,DbFi);
- m_Lc.iSubItem=i;
- m_Lc.fmt=LVCFMT_CENTER;
- m_Lc.cx=DbFi.m_strName.GetLength()*10+16;
- m_Lc.pszText=DbFi.m_strName.GetBuffer(DbFi.m_strName.GetLength());
- GetListCtrl().InsertColumn(i,&m_Lc);
- }
- //根据记录集的数据信息添加行
- LV_ITEM m_item;//条目结构体对象
- CString string;//字符串临时变量
- CDBVariant DbVariant;
- i=0;
- if(m_pSet->IsEOF())//记录集是否为空
- {
- AfxMessageBox("记录集没有记录");
- return;
- }
- m_pSet->MoveFirst();//从第一个记录开始
- while(m_pSet->IsEOF()==0)//是否到达最后一个记录
- {
复制代码- m_item.mask=LVIF_TEXT;
- m_item.iItem=i;
- m_item.iSubItem=0;
- m_pSet->GetFieldValue((short)0,string);
- m_item.pszText=string.GetBuffer(string.GetLength());
- m_List->InsertItem(&m_item);//插入条目
- //显示列数据
- for(j=1;j<m_pSet->m_nFields;j++)
- {
- m_pSet->GetFieldValue((short)j,string);
- m_List->SetItemText(i,j,string.GetBuffer(string.GetLength()));
- }
- m_pSet->MoveNext();//下移记录
- i++;
- }
- }
复制代码我们来演示功能实现的整个过程、
|