工控编程吧
标题:
81上位机VC MFC树视图加载显示数据库数据
[打印本页]
作者:
qq263946146
时间:
2015-12-14 20:44
标题:
81上位机VC MFC树视图加载显示数据库数据
(, 下载次数: 2)
上传
点击文件名下载附件
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")
我们来演示下功能实现的整个过程
[iqiyi]http://player.video.qiyi.com/8b15d87d118dd3174ad27780da82a650/0/0/w_19rt6lugk5.swf-albumId=5018692409-tvId=5018692409-isPurchase=0-cnId=12[/iqiyi]
(, 下载次数: 0)
上传
点击文件名下载附件
[note]1[/note]
欢迎光临 工控编程吧 (https://www.gkbc8.com/)
Powered by Discuz! X3.4