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

本文介绍使用C#从数据库加载省市数据并生成树状菜单的过程。通过连接数据库,执行SQL查询获取省市信息,实现动态生成树形节点,解决节点重复问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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";

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值