ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

c#调用数据库生成树形节点时节点重复的问题

2020-11-28 12:01:16  阅读:247  来源: 互联网

标签:Province City Addr c# 树形 using Nodes 节点


c#调用数据库生成树形节点时节点重复的问题


小白一个,最近跟着老师做项目的时候需要从数据库调用省市数据生成树状菜单,网上大多是几点需要手动输入的,

效果图

在这里插入图片描述

代码段

using System;
using System.Data;
using System.Drawing;
using System.Windows.Forms;
using System.Data.Odbc;
using System.Configuration;
using System.IO;

namespace Treeview
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        /// <summary>
        /// 打开窗口默认加载
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Form1_Load(object sender, EventArgs e)
        {
            string conStr = ConfigurationManager.ConnectionStrings["constr"].ConnectionString;   //连接数据库,using引入configuration,解决方案管理器添加引用
            OdbcConnection conn = new OdbcConnection(conStr);
            conn.Open();
            string mysql = "SELECT Addr_Prov, Addr_City FROM Basic_Info GROUP BY Addr_City";
            OdbcCommand cmd = new OdbcCommand(mysql, conn);
            OdbcDataReader reader = cmd.ExecuteReader();
            while (reader.Read())
            {
                int i = 0;
                string Addr_Prov = reader[0].ToString();
                string Addr_City = reader[1].ToString();
                TreeNode Province = new TreeNode(Addr_Prov);                             //新建节点名称为Province,存放Addr_Prov数据
                TreeNode City = new TreeNode(Addr_City);                                  //新建节点名称为City,存放Addr_City数据

                //判断要加的父节点是否存在,如存在,将子节点加到已存在的父节点中,若不存在则新加一个父节点,并将子节点加入
                //若果没有节点,先添加一个
                if (AddrTreeView.Nodes.Count == 0)
                {
                    AddrTreeView.Nodes.Add(Province);                                   //将Province加为父节点
                    Province.Nodes.Add(City);                                           //将City加入到Province作为其子节点
                }
                else
                {
                    //从第一个节点开始遍历,如果第(i+1)个节点和当前的Addr_Prov一样,则次节点已经存在,往此节点添加子节点,跳出while循环
                    while (i < AddrTreeView.Nodes.Count)
                    {
                        string prov = AddrTreeView.Nodes[i].Text.ToString();
                        if (prov == Addr_Prov)
                        {
                            AddrTreeView.Nodes[i].Nodes.Add(City);
                            break;
                        }
                        i++;
                    }
                    //判断循环有没有进行到最后,如果有,说明没有已存在和Addr_Prov一样的节点(有的话会提前跳出循环,i停留在跳出循环时的值,加入父节点和对应的子节点
                    if (i == AddrTreeView.Nodes.Count)
                    {
                        AddrTreeView.Nodes.Add(Province);                           //将Province加为父节点                                                                                 
                        Province.Nodes.Add(City);
                    }
                }
            }
            reader.Close();
            conn.Close();
        }
    }
}

注意

数据库查询语句,

string mysql = "SELECT Addr_Prov, Addr_City FROM Basic_Info GROUP BY Addr_City";

查出结果是
在这里插入图片描述

标签:Province,City,Addr,c#,树形,using,Nodes,节点
来源: https://blog.csdn.net/piqiangqiang/article/details/110262625

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有