C#创建树形结构

string connString = "User ID=sys;Password=sys;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.11)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = orcl)))";
            OracleConnection conn = new OracleConnection(connString);
            try
            {
                //连接数据库
                conn.Open();
                //查询数据库
                OracleCommand cmd = conn.CreateCommand();
                cmd.CommandText = "select no,name from sys.t_org where type=1 ";
                OracleDataReader dr=cmd.ExecuteReader();
                if (dr.HasRows)
                {
                  while(dr.Read()){
                      string no = dr["no"].ToString();
                      string name = dr["name"].ToString();
                      TreeNode node = new TreeNode();
                      node.Name = no;
                      node.Text = name;
                      directoryTree.Nodes.Add(node);
                      cTree(node,node.Name);
                  }
                }


               // MessageBox.Show(conn.State.ToString());
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message.ToString());
            }
            finally
            {
                conn.Close();

            }

递归方法:

 string connString = "User ID=sys;Password=sys;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.11)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = orcl)))";
            OracleConnection conn = new OracleConnection(connString);
            try
            {
                //连接数据库
                conn.Open();
                //查询数据库
                OracleCommand cmd = conn.CreateCommand();
                cmd.CommandText = "select no,name from sys.t_org where p_no='"+node.Name+"'";
                OracleDataReader dr = cmd.ExecuteReader();
                if (dr.HasRows)
                {
                    while (dr.Read())
                    {
                        string no = dr["no"].ToString();
                        string name = dr["name"].ToString();
                        TreeNode nodes = new TreeNode();
                        nodes.Name = no;
                        nodes.Text = name;
                       
                        node.Nodes.Add(nodes);
                        cTree(nodes,nodes.Name);
                    }
                }      
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message.ToString());
            }
            finally
            {
                conn.Close();
            }

      效果图:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值