文章详情

短信预约信息系统项目管理师 报名、考试、查分时间动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SQLServer 实现简单的省市区联动

2015-05-20 23:23

关注

SQLServer 实现简单的省市区联动

今天研究了一下SQL Server实现省市区联动的方法,记录一下。

一、先创建三个表,Dic_Area(区)、Dic_City(市)和Dic_Province(省),三个表建表语句如下:

1 create table Dic_Province
2 (
3   id int NOT NULL,
4   provinceID varchar(6) default NULL,
5   province varchar(40) default NULL,
6   PRIMARY KEY  (id)
7 )
Dic_Province
1 create table Dic_City
2 (
3   id int NOT NULL,
4   cityID varchar(6) default NULL,
5   city varchar(50) default NULL,
6   provinceid varchar(6) default NULL,
7   PRIMARY KEY  (id)  
8 )
Dic_City
1 CREATE TABLE Dic_Area 
2 (
3   id int NOT NULL,
4   areaID varchar(50) default NULL,
5   area varchar(60) default NULL,
6   cityID varchar(6) default NULL,
7   primary key(id)
8 )
Dic_Area

插入数据,(数据来源https://www.cnblogs.com/zhu520/p/8244578.html),因为实在是有点懒,只能网上借用一下这位兄台的数据了。插入数据就不说了,复制或者下载过来改一下表名执行就ok。

 

二、新建一个Windows窗体应用,插入3个ComboBox,命名分别为:cbo_Province、cbo_City、cbo_District。

先声明一个连接字符串:

1 private string connStr = @"Data Source=SD-20191219LHFXSQLEXPRESS;Initial Catalog=AreaSelection;User ID=sa;Password=***********"; //连接字符串

接下来在Form1_Load中添加预加载代码,程序运行的时候ComboBox中就要加载显示地区信息。

1 private void Form1_Load(object sender, EventArgs e)
2 {
3      LoadingProvice();
4 }

为了代码清晰,我把省市区分别封装成三个方法:LoadingProvice()、LoadingCity()、LoadingDistrict()。

但是在这之前,我们要先构造一个集合,因为cbo_Province可以调用DataSource这个方法。三个表中,每个表都有ID和地区名字,所以新建一个类AreaInfo.cs就可以了:

在AreaInfo中添加下面的代码:

1 public partial class AreaInfo
2 {
3     public int Id { get; set; } //ID
4     public string Title { get; set; } //地区名字
5 }

接下来就可以写方法了:(以下分别是省、市、区)

 1 private void LoadingProvice()
 2 {
 3     List list = new List();
 4     using(SqlConnection conn = new SqlConnection(connStr))
 5     {
 6          string sql = "select * from Dic_Province";
 7          SqlCommand cmd = new SqlCommand(sql, conn);
 8          conn.Open();
 9          SqlDataReader reader = cmd.ExecuteReader();
10 
11          while (reader.Read())
12          {
13              //添加元素
14              list.Add(new AreaInfo()
15              {
16                  //初始化器
17                  Id = Convert.ToInt32(reader["ProvinceID"]),
18                  Title = reader["Province"].ToString()
19              });
20          }
21      }
22      cbo_Province.DisplayMember = "Title"; //显示属性
23      cbo_Province.ValueMember = "Id"; //值属性
24      cbo_Province.DataSource = list;
25 }
 1 private void LoadingCity()
 2 {
 3      int pid = Convert.ToInt32(cbo_Province.SelectedValue);
 4      List list = new List();
 5      string sql = "select * from Dic_City where provinceid = @pid";
 6      using(SqlConnection conn = new SqlConnection(connStr))
 7      {
 8           SqlCommand cmd = new SqlCommand(sql, conn);
 9           cmd.Parameters.Add(new SqlParameter("@pid", pid));
10           conn.Open();
11           SqlDataReader reader = cmd.ExecuteReader();
12           while(reader.Read())
13           {
14                list.Add(new AreaInfo()
15                {
16                     Id = Convert.ToInt32(reader["cityID"]),
17                     Title = reader["city"].ToString()
18                });
19           }
20      }
21      cbo_City.DisplayMember = "Title";
22      cbo_City.ValueMember = "Id";
23      cbo_City.DataSource = list;
24 }
 1 private void LoadingDistrict()
 2 {
 3      List list = new List();
 4      int cid = Convert.ToInt32(cbo_City.SelectedValue);
 5      string sql = "select * from Dic_Area where cityID = @cid";
 6      using(SqlConnection conn = new SqlConnection(connStr))
 7      {
 8           SqlCommand cmd = new SqlCommand(sql, conn);
 9           cmd.Parameters.Add(new SqlParameter("@cid", cid));
10           conn.Open();
11           SqlDataReader reader = cmd.ExecuteReader();
12           while(reader.Read())
13           {
14                list.Add(new AreaInfo()
15                {
16                    Id = Convert.ToInt32(reader["areaID"]),
17                    Title = reader["area"].ToString()
18                });
19           }
20        }
21        cbo_District.DisplayMember = "Title";
22        cbo_District.ValueMember = "Id";
23        cbo_District.DataSource = list;
24 }

每个方法大同小异,都是对数据库的基本操作,就没进行过多的注释。

最后在comboBox的SelectedIndexChanged方法中添加方法名,如下:

1 private void cbo_provice_SelectedIndexChanged(object sender, EventArgs e)
2 {
3       LoadingCity();
4       LoadingDistrict();
5 }
1 private void cbo_City_SelectedIndexChanged(object sender, EventArgs e)
2 {
3       LoadingDistrict();
4 }

cbo_District控件下面就不需要添加方法了,因为区下面就没有分类了。

完成界面如下:

 

 

 

 

 

 

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯