C# 递归生产树 TreeView

 需要添加到TreeView 中的数据在数据库中的存储表: 

 

C# 递归生产树 TreeView_第1张图片

 

ID 为主键,PID 表明数据之间的关系。

 

/// 
/// 生产树的代码;
/// 
///  根节点
/// 主键

        private void CreateTwo(TreeNode node, int id)
        {
            string strSql = "select * from TableTest where PID = " + id;
            DataTable dt = SqlClass.GetTable(strSql);
            if (id == 0)                                             // id = 0 是根节点 
            {
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    TreeNode nd = new TreeNode();
                    nd.Text = dt.Rows[i]["Name"].ToString();
                    CreateTwo(nd, Convert.ToInt32(dt.Rows[i]["id"].ToString()));
                    tvwTwo.Nodes.Add(nd);
                }
            }
            else
            {
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    TreeNode Tnode = new TreeNode();
                    Tnode.Text = dt.Rows[i]["Name"].ToString();
                    CreateTwo(Tnode, Convert.ToInt32(dt.Rows[i]["id"].ToString()));
                    node.Nodes.Add(Tnode);
                }
            }
        }


则个代码比较简单 只需要查询一个数据表。

生成结果:

C# 递归生产树 TreeView_第2张图片

 

 

 

 

 

 

  

转载于:https://www.cnblogs.com/igoogleyou/archive/2012/12/17/treeview2.html

你可能感兴趣的:(C# 递归生产树 TreeView)