C# 里TreeView绑定数据库实现分类

codes=c#]
//从数据库中读取数据
            SqlConnection con = new SqlConnection("server=127.0.0.1//sqlexpress;uid=sa;");
            con.Open();
            con.ChangeDatabase("STggggg");
            SqlCommand cmd = new SqlCommand("select * from 产品树 where NodeType='f'", con);
            //cmd.CommandType = CommandType.StoredProcedure;
            SqlDataAdapter sda = new SqlDataAdapter(cmd);
            DataSet ds = new DataSet();
            try
            {
                sda.Fill(ds);
            }
            catch
            {
            }
            finally
            {
                cmd = null;
                con.Close();
            }
            //往TreeView中添加树节点
            //添加根节点
            TreeNode tn = new TreeNode();
            tn.Text = "所有产品";
            tn.Name = "0";//Name作为ID
            tn.Tag = "0";//Tag作为RootID
            tn.ImageIndex = 0;
            tn.SelectedImageIndex = 0;
            tv.Nodes.Add(tn);//该TreeView命名为tv
            tv.SelectedNode = tv.TopNode;
            //把其他节点加上去
            if (ds != null)
            {[/codes][codes=c#]
                foreach (DataRow dr in ds.Tables[0].Rows)
                {
                    tn = new TreeNode();
                    tn.Text = dr["Product"].ToString();
                    tn.Name = dr["CateID"].ToString();//Name作为CateID
                    tn.Tag = dr["RootID"].ToString();//Tag作为RootID
                    tn.ImageIndex = 1;
                    tn.SelectedImageIndex = 1;
                    //判断是否为主节点
                    if (dr["CateID"].ToString() == dr["RootID"].ToString())
                    {
                        //主节点
                        tv.SelectedNode = tv.TopNode;
                    }
                    else
                    {
                        //其他节点
                        if (tv.SelectedNode.Name != dr["ParentID"].ToString())
                        {
                            TreeNode[] tn_temp = tv.Nodes.Find(dr["ParentID"].ToString(), true); //通过ParentID查找父节点
                            if (tn_temp.Length > 0)
                            {
                                tv.SelectedNode = tn_temp[0]; //选中查找到的节点
                            }
                        }
                    }
                    tv.SelectedNode.Nodes.Add(tn);
                }
                //tv.ExpandAll();//展开TreeView
                tv.SelectedNode = tv.TopNode; //最顶端节点选中
            }
[/codes]

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zhangjie_xiaoke/archive/2009/12/14/5000340.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值