VC操作SQL Server主从表
2010-02-19 20:33:16 来源:WEB开发网三、列表视图的操作及事件处理
说句实话,列表的属性参数很多,标准的、扩展的风格参数一大堆,看看那些英文文档,在其中苦苦搜寻,找一条自己需要的特性,其中的滋味别提了。还好我很有耐心:)熟练了就好了,都记住了一大半,还怕什么。列表控件显示数据,要用LVS_REPORT风格,比较好看,就像DataGrid一样。设置窗口风格需要用SetWindowLong这个API函数。这个函数是通用的。参数也一大堆。处理列表的单击事件即是处理消息NM_CLICK,处理选择改变时的事件即是处理LVN_ITEMCHANGED,不同的消息可能参数不同,需区别对待。
void CDagView::OnItemchanged(NMHDR* pNMHDR, LRESULT* pResult)
{
NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;
// TODO: Add your control notification handler code here
CListCtrl& refListCtrl=GetListCtrl();
if(pNMListView->uNewState&LVIS_SELECTED)
…//选取列表项时,事件触发
pResult=0;
}
同样的方法处理单击,双击等事件,不再嗷述。
四、树形控件的操作及事件处理,利用递归根据数据库动态生成目录
树形控件,和列表控件一样,在VC数据开发中有着非常重要的地位。常用来显示分级,分类信息。其实,提到树,脑海里就出现一大堆树,什么二叉树,查找树,哈夫曼树等一大堆,也就想起了遍历树的常用算法—递归。虽然采用堆栈更有效率,但使用递归常使程序设计简化。
看以下程式片段:
pRS->MoveFirst();
_variant_t var;
CString strTableName,strTableCode;
HTREEITEM hChildItem;
while(!pRS->adoEOF)
{
var=pRS->GetCollect("menucode");
if(var.vt != VT_NULL)
strTableCode = (LPCSTR)_bstr_t(var);
//此即函数递归出口
if(!strTableCode.Find(strParent,0) &&
strTableCode.GetLength()==strParent.GetLength()+2)
{
hChildItem=refTree.InsertItem(strTableName,hTreeNode,TVI_LAST);
InitTree(refTree,hChildItem,strTableCode);
}
pRS->MoveNext();
}
递归时充分利用树形结构的特点。然后结合递归思想,融合在一起,就行了。这里就是理论和实际的结合点。不同的开发语言提供的操作接口是不同的,如Delphi、.dotnet。我呈在在.net也实现了一个类似的树,算法思想一样,只是具体操作不同,因为dotnet提供的接口不同。
树形控件的事件处理:
void CClassTreeView::OnSelchanged(NMHDR* pNMHDR, LRESULT* pResult)
{
NM_TREEVIEW* pNMTreeView = (NM_TREEVIEW*)pNMHDR;
// TODO: Add your control notification handler code here
CTreeCtrl& refTreeCtrl=GetTreeCtrl();
HTREEITEM hSelected=pNMTreeView->itemNew.hItem;
if(hSelected!=NULL)
{
m_strMenuName=refTreeCtrl.GetItemText(hSelected);
if(AfxGetMainWnd()->IsWindowEnabled())
UpdateDagView();
}
//-----------
*pResult = 0;
}
- ››sql server自动生成批量执行SQL脚本的批处理
- ››sql server 2008亿万数据性能优化
- ››SQL Server 2008清空数据库日志方法
- ››sqlserver安装和简单的使用
- ››SQL Sever 2008 R2 数据库管理
- ››SQL SERVER无法安装成功,sqlstp.log文件提示[未发...
- ››Sql Server中通过父记录查找出所有关联的子记录
- ››SqlServer触发器、存储过程和函数
- ››SQL Server 中的事务(含义,属性,管理)
- ››VC++实现360安全桌面背景
- ››Sqlite数据库插入和读取图片数据
- ››Sql server 2005拒绝了对对象 'xx表' (数...
更多精彩
赞助商链接