C#编程之ComboBox的联动操作(三层架构)
Vivian 2018-05-22 来源 : 阅读 2598 评论 0

摘要:本次的C#编程讲述的是ComboBox的联动操作,通过具体的步骤,让大家学习到ComboBox的联动操作的关键所在,希望对大家学习C#编程有所帮助。

本次的C#编程讲述的是ComboBox的联动操作,通过具体的步骤,让大家学习到ComboBox的联动操作的关键所在,希望对大家学习C#编程有所帮助。

项目需求:根据年级下拉框的变化使得科目下拉框绑定次年级下对应有的值

 C#编程之ComboBox的联动操作(三层架构)

我们用三层架构的模式来实现

 C#编程之ComboBox的联动操作(三层架构)

1.我们想和数据库交互,我们首先得来先解决DAL数据库交互层

 C#编程之ComboBox的联动操作(三层架构)

01.获得年级下拉框的数据

在GradeDAL类中

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient;
using System.Data;
using MySchool.Model;
using System.Configuration;
namespace MySchool.DAL
{
 //数据访问层
 public class GradeDAL
 {
  public static string Constr = ConfigurationManager.ConnectionStrings["constr"].ConnectionString;
  #region 获得年级表
   public DataTable SelectGrade(string gradetype)
  {
   //和数据库交互
   string str = "Data Source=.;initial catalog=MySchool;uid=sa";
   SqlConnection con = new SqlConnection(str);
   string sql = "";
   if (gradetype=="")
   {
    sql = "select * from Grade";
   }
   else
   {
    sql = "select * from Student where GradeId in (select GradeId from Grade where GradeName='" + gradetype + "')";
   }
    
   SqlDataAdapter da = new SqlDataAdapter(sql, con);
   DataSet ds = new DataSet();
   //捕获异常
   try
   {
    da.Fill(ds, "stuInfo");
   }
   catch (Exception ex)
   {
 
    throw new Exception(ex.Message);
   }
   //返回一张表的数据
   return ds.Tables["stuInfo"];
  }
  #endregion
 
  #region 获取年级数据,为在下拉框中显示
   //定义一个集合,储存年级信息
   List<Grade> list = new List<Grade>();
   #region 方法一: 以返回表的方式
   public DataTable LoadCombox()
   {
    string sql = "select * from Grade";
    DataTable dt = SQLHelper.ExecuteDataTable(sql);
    return dt;
   }
   #endregion
 
   #region 方法二:以返回集合的方式
 
   public List<Grade> Loadcombox2()
   {
    string sql = "select * from Grade";
    DataTable dt = SQLHelper.ExecuteDataTable(sql);
    //方法一:
    foreach (DataRow row in dt.Rows)
    {
     //每一个row代表表中的一行,所以一行对应一个年级对象
     Grade grade = new Grade();
     grade.GradeId = Convert.ToInt32(row["gradeid"]);
     grade.GradeName = row["gradename"].ToString();
     list.Add(grade);
    }
    //方法二:(使用MyTool类)
 
    //MyTool tool=new MyTool();
    //list = tool.DataTableToList<Grade>(dt);
    return list;
   }
  #endregion
 
   #region 方法三:要求使用using语句
   public List<Grade> LoadCombox3()
   {
    //using的作用可以释放资源,利于资源的回收(可以省略关闭连接)
    using (SqlConnection con=new SqlConnection(Constr))
    {
     try
     {
      string sql = "select * from Grade";
      SqlCommand cmd = new SqlCommand(sql,con);
      con.Open();
      SqlDataReader dr = cmd.ExecuteReader();
      while (dr.Read())
      {
       Grade gr = new Grade();
       gr.GradeId = Convert.ToInt32(dr["GradeId"]);
       gr.GradeName=dr["GradeName"].ToString();
       list.Add(gr);
      }
     
     }
     catch (Exception ex)
     {
 
      throw new Exception(ex.Message);
     }
    }
    return list;
   }
  #endregion
 
   #endregion
 
   
   
 
   
 }
}

   

02.在业务逻辑层

C#编程之ComboBox的联动操作(三层架构)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using MySchool.DAL;
using System.Data;
using MySchool.Model;
namespace MySchool.BLL
{
 public class GradeBLL
 {
  GradeDAL gradedal = new GradeDAL();
  #region 获取年级数据,为在下拉框中显示
 
  public DataTable SelectGrade(string gradetype)
  {
   return gradedal.SelectGrade(gradetype);
  }
 
  public DataTable LoadCombox()
  {
   return gradedal.LoadCombox();
  }
   
 
  public List<Grade> Loadcombox2()
  {
   return gradedal.Loadcombox2();
  }
 
 
  #endregion
 
  public List<Grade> LoadCombox3()
  {
   return gradedal.LoadCombox3();
  }
 
   
 }
}

   

03.在窗体UI层

在Load事件中加载年级下拉框


private void FrmSelectResult_Load(object sender, EventArgs e)
 {
  #region 加载年级下拉框
  try
  {
   List<Grade> list = gradedal.LoadCombox3();
   list.Insert(0, new Grade() { GradeId=-1,GradeName="--全部--" });
   cboGrade.ValueMember = "GradeId";
   cboGrade.DisplayMember = "GradeName";
   cboGrade.DataSource = list;
  }
  catch (Exception ex)
  {
 
   MessageBox.Show(ex.Message);
  }
   
   
  #endregion
 
  #region 加载科目下拉框
  //try
  //{
  // list2 = subjectdal.LoadComboxSub();
  // list2.Insert(0, new Subject() { SubjectId = -1, SubjectName = "--全部--" });
  // cboSubject.ValueMember = "SubjectId";
  // cboSubject.DisplayMember = "SubjectName";
  // cboSubject.DataSource = list2;
  //}
  //catch (Exception ex)
  //{
 
  // MessageBox.Show(ex.Message);
  //}
   
  #endregion
 }

   

其中在使用

获得年级下拉框隐藏值得方法(2)
int num = Convert.ToInt32(cboGrade.SelectedValue);

加载年级下拉框时:会出现的错误的写法

把cboGrade.DataSource = list;写在
 cboGrade.ValueMember = "GradeId";
 cboGrade.DisplayMember = "GradeName";上面
即:

#region 加载年级下拉框
  try
  {
   List<Grade> list = gradedal.LoadCombox3();
   list.Insert(0, new Grade() { GradeId=-1,GradeName="--全部--" });
   cboGrade.DataSource = list;
   cboGrade.ValueMember = "GradeId";
   cboGrade.DisplayMember = "GradeName";
    
    
  }
  catch (Exception ex)
  {
 
   MessageBox.Show(ex.Message);
  }
   
   
  #endregion

   

这是就会出现下面错误:

 C#编程之ComboBox的联动操作(三层架构)

在年级的SelectedIndexChanged事件中

try
  {
 
   //根据年级取得科目信息并绑定
   #region 获得年级下拉框隐藏值得方法(1)
   Grade sub = (Grade)cboGrade.SelectedItem;
   int num =sub.GradeId;
   #endregion
 
   #region 获得年级下拉框隐藏值得方法(2)
   // int num = Convert.ToInt32(cboGrade.SelectedValue.ToString());
   #endregion
    
   List<Subject> list = subjectdal.LoadComboxSub2(num);
    
   cboSubject.ValueMember = "SubjectId";
   cboSubject.DisplayMember = "SubjectName";
   cboSubject.DataSource = list;
    
 
    
  }
  catch (Exception)
  {
 
   MessageBox.Show("出错");
  }

   

本文由职坐标整理并发布,了解更多内容,请关注职坐标编程语言C#.NET频道!


本文由 @Vivian 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程