无限极分类装入Treeview

Declare @Id Int
Set @Id = 0; ---在此修改父节点

With RootNodeCTE(NodeId,ParentId,[text],orderid)
As
(
Select NodeId,ParentId,[text],orderid From S_Tree Where ParentId In (@Id)
Union All
Select S_Tree.NodeId,S_Tree.ParentId,S_Tree.[text],s_tree.orderid From RootNodeCTE
Inner Join S_Tree
On RootNodeCTE.NodeId = S_Tree.ParentId
)

Select * From RootNodeCTE order by ParentId,NODEID asc

 

private void btnTreeView_Click(object sender, EventArgs e)
{
string xmlFile = @"E:\XML_F.xml";
DataSet ds = new DataSet();
ds.ReadXml(xmlFile);
DataTable dt = ds.Tables[0];
DataRow[] drss = dt.Select("ParentId = '38'");

string parentId = "0";
TreeNode treeNodeParent = new TreeNode("DataItems");
treeView1.Nodes.Add(treeNodeParent);
GenerateTree(parentId, dt, treeNodeParent);
treeView1.ExpandAll();
}

/// <summary>
///
/// </summary>
private void GenerateTree(string parentId, DataTable dt, TreeNode treeNodeParent)
{
string strWhere = " ParentId = '" + parentId + "'";
DataRow[] drs = dt.Select(strWhere);
if (drs.Length > 0)
{
foreach (DataRow dr in drs)
{
parentId =dr[0].ToString();
TreeNode treeNode = new TreeNode();
treeNode.Tag = dr[0].ToString();
treeNode.Text = dr[2].ToString() + "[" + dr[0].ToString() + "]";
treeNodeParent.Nodes.Add(treeNode);

GenerateTree(parentId, dt, treeNode);
}
}
}

转载于:https://www.cnblogs.com/zhangchenliang/archive/2012/03/12/2392660.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值