欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# ComboBox的聯(lián)動操作(三層架構)

 更新時間:2016年05月11日 08:55:12   作者:天盡頭的那片海  
這篇文章主要介紹了C# ComboBox的聯(lián)動操作(三層架構),根據下拉框的變化使得下拉框綁定對應值,感興趣的小伙伴們可以參考一下

項目需求:根據年級下拉框的變化使得科目下拉框綁定次年級下對應有的值

我們用三層架構的模式來實現

1.我們想和數據庫交互,我們首先得來先解決DAL數據庫交互層

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.在業(yè)務邏輯層

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

這是就會出現下面錯誤:

在年級的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#程序設計有所幫助。

相關文章

  • 淺析C#?AsyncLocal如何在異步間進行數據流轉

    淺析C#?AsyncLocal如何在異步間進行數據流轉

    在異步編程中,處理異步操作之間的數據流轉是一個比較常用的操作,C#異步編程提供了一個強大的工具來解決這個問題,那就是AsyncLocal,下面我們就來看看AsyncLocal的原理和用法吧
    2023-08-08
  • 關于C#理解裝箱與拆箱

    關于C#理解裝箱與拆箱

    這篇文章主要介紹了關于C語言理解裝箱與拆箱的相關資料,需要的朋友可以參考下面文章內容
    2021-09-09
  • c# socket網絡編程接收發(fā)送數據示例代碼

    c# socket網絡編程接收發(fā)送數據示例代碼

    這篇文章主要介紹了c# socket網絡編程,server端接收,client端發(fā)送數據,大家參考使用吧
    2013-12-12
  • 基于C#實現在圖片上繪制文字

    基于C#實現在圖片上繪制文字

    這篇文章主要為大家詳細介紹了如何利用C#實現在圖片上繪制文字的效果,文中的示例代碼講解詳細,對我們學習C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下
    2022-12-12
  • C#和JavaScript實現交互的方法

    C#和JavaScript實現交互的方法

    最近做一個小項目不可避免的需要前端腳本與后臺進行交互。由于是在asp.net中實現,故問題演化成asp.net中jiavascript與后臺c#如何進行交互。
    2015-05-05
  • 利用C#實現將小數值四舍五入為整數

    利用C#實現將小數值四舍五入為整數

    在項目的開發(fā)中,遇到一些除法計算內容會產生小數值,但是又需要根據項目的實際情況將這些小數內容化為整數,所以本文為大家整理了C#實現將小數值四舍五入為整數的方法,希望對大家有所幫助
    2023-07-07
  • 淺析C#更改令牌ChangeToken

    淺析C#更改令牌ChangeToken

    這篇文章主要介紹了C#更改令牌ChangeToken,文中運用大量代碼講解的非常詳細,感興趣的小伙伴一起來看看這篇文章吧
    2021-09-09
  • WinForm繪制圓角的方法

    WinForm繪制圓角的方法

    這篇文章主要介紹了WinForm繪制圓角的方法,涉及C#中GraphicsPath模塊的使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-08
  • C#判斷本地文件是否處于打開狀態(tài)的方法

    C#判斷本地文件是否處于打開狀態(tài)的方法

    這篇文章主要介紹了C#判斷本地文件是否處于打開狀態(tài)的方法,涉及C#操作文件的技巧,非常具有實用價值,需要的朋友可以參考下
    2015-05-05
  • c#遠程html數據抓取實例分享

    c#遠程html數據抓取實例分享

    這篇文章主要介紹了c#遠程html數據抓取的方法,大家參考使用吧
    2013-12-12

最新評論