81上位机VC MFC树视图加载显示数据库数据
81上位机VC MFC树视图加载显示数据库数据
功能展示
有时为了能够将数据库内数据非常清晰的表达数据间的层次关系,就会用到树状视图控件,我们当前例程就使用树状视图加载与显示数据库文件数据,效果如图; 要点提示 在使用树视图控件时,常用到的函数 有SetImageList()关联图像列表;InsertItem()插入数据;GetNextItem()遍历数据; InsertItem()查阅MSDN手册语法有很多,我们当前例程使用HTREEITEMInsertItem( LPCTSTR lpszItem, int nImage, int nSelectedImage, HTREEITEM hParent = TVI_ROOT,HTREEITEM hInsertAfter = TVI_LAST); lpszItem节点文本; hParent 父节点句柄; nImage, nSelectedImage为节点及选中图像的索引; hInsertAfter 标识新播放节点后面的节点句柄;
实现功能 1.新建基于对话框的应用程序 2.拖拽一树状视图控件关联变量CTreeCtrl m_Tree;添加一图片列表变量 CImageList m_TreeImageList;用于设置树状视图控图标用;
3.添加一函数AddtoTree(HTREEITEM node,int UPID)用于向树状视图添加节点,再进行初始化操作给树状视图从数据库读取数据添加到树状视图中 - void CGkbc8Dlg::AddtoTree(HTREEITEM node,int UPID)
- {
- HTREEITEM CHILDROOT;
- for(int i=0;i<a_upid.GetSize();i++)
- {
- if(UPID==atoi(a_upid.GetAt(i)))
- {
- switch(atoi(a_lx.GetAt(i)))
- {
- case 1:
- CHILDROOT = m_Tree.InsertItem(a_name.GetAt(i),2,2,node);
- AddtoTree(CHILDROOT,atoi(a_id.GetAt(i)));
- break;
- case 2:
- CHILDROOT = m_Tree.InsertItem(a_name.GetAt(i),1,1,node);
- AddtoTree(CHILDROOT,atoi(a_id.GetAt(i)));
- break;
- case 3:
- CHILDROOT = m_Tree.InsertItem(a_name.GetAt(i),3,3,node);
- AddtoTree(CHILDROOT,atoi(a_id.GetAt(i)));
- break;
- }
- }
- }
- }
复制代码- //
- m_TreeImageList.Create(16,16,ILC_MASK,4,1);
- m_TreeImageList.Add(AfxGetApp()->LoadIcon(IDI_ICON1));
- m_TreeImageList.Add(AfxGetApp()->LoadIcon(IDI_ICON2));
- m_TreeImageList.Add(AfxGetApp()->LoadIcon(IDI_ICON3));
- m_TreeImageList.Add(AfxGetApp()->LoadIcon(IDI_ICON4));
- m_Tree.SetImageList(&m_TreeImageList,LVSIL_NORMAL);
- HTREEITEM ROOT;
- ROOT=m_Tree.InsertItem("工控编程",0,0);
- //初始化数据库
- _ConnectionPtr m_pConnection;//Connection对象的指针
- _RecordsetPtr m_pRecordset;//Recordset对象的指针
- ::CoInitialize(NULL);//初始化OLE/COM库环境
- m_pConnection.CreateInstance("ADODB.Connection");//创建connection对象
- _bstr_t strConnect="uid=;pwd=;DRIVER={Microsoft Access Driver (*.mdb)};DBQ=Shujuku.mdb;";//设置连接字符串
- m_pConnection->Open(strConnect,"","",adModeUnknown);//SERVER和UID,PWD的设置根据实际情况来设置
- _bstr_t vSQL;
- vSQL="SELECT*FROM shuju ORDER BY id";//设置SQL语句
- m_pRecordset.CreateInstance(__uuidof(Recordset));//创建记录集对象
- m_pRecordset->Open(vSQL,m_pConnection.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);//取得表中的记录
- //加载数据
- a_id.RemoveAll();
- a_upid.RemoveAll();
- a_lx.RemoveAll();
- a_name.RemoveAll();
- while(m_pRecordset->adoEOF==0)
- {
- a_id.Add((LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("id"));
- a_upid.Add((LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("upid"));
- a_lx.Add((LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("lx"));
- a_name.Add((LPCTSTR)(_bstr_t)m_pRecordset->GetCollect("name"));
- m_pRecordset->MoveNext();
- }
复制代码- m_pRecordset->Close();
- m_pConnection->Close();
- //将从数据库加载的数据添加到树状列表中
- AddtoTree(ROOT,0);
- m_Tree.Expand(ROOT,TVE_EXPAND);//展开
复制代码其中CStringArraya_id; CStringArray a_upid; CStringArray a_lx; CStringArray a_name; 为全局变量 例程中涉及数据库的操作所以所加载动态库文件,添加一句便可#import "C:\Program Files\CommonFiles\System\ado\msado15.dll" no_namespacerename("EOF","adoEOF")rename("BOF","adoBOF")
我们来演示下功能实现的整个过程
|