VC 操作 SQL Server 主从表
2006-07-23 11:17:17 来源:WEB开发网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();
递归时充分利用树形结构的特点。然后结合递归思想,融合在一起,就行了。这里就是理论和实际的结合点。不同的开发语言提供的操作接口是不同的,如Delphi、.dotnet。我呈在在.net也实现了一个类似的树,算法思想一样,只是具体操作不同,因为dotnet提供的接口不同。
_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();
}
- ››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表' (数...
更多精彩
赞助商链接