ComboBox的聯動(三層架構)

来源:http://www.cnblogs.com/zhangzongle/archive/2016/03/31/5341731.html
-Advertisement-
Play Games

需求:根據年級下拉框的變化使得科目下拉框綁定次年級下對應有的值 我們用三層架構的模式來實現 1.我們想和資料庫交互,我們首先得來先解決DAL資料庫交互層 01.獲得年級下拉框的數據 在GradeDAL類中 02.在業務邏輯層 03.在窗體UI層 在Load事件中載入年級下拉框 其中在使用 獲得年級下 ...


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

 

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

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.在業務邏輯層

   

    

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("出錯");
            }

 

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 重定向和轉發有一個重要的不同:當使用轉發時,JSP容器將使用一個內部的方法來調用目標頁面,新的頁面繼續處理同一個請求,而瀏覽器將不會知道這個過程。 與之相反,重定向方式的含義是第一個頁面通知瀏覽器發送一個新的頁面請求。因為,當你使用重定向時,瀏覽器中所顯示的URL會變成新頁面的URL, 而當使用轉發 ...
  • java中equal和==的區別: equal方法除非進行了重寫(比如String類和基本類型包裝類),否則都是進行對象引用的比較。而==除了比較基本類型時是比較值,其他情況均是比較引用地址。 java適配器模式? 將原來的實現介面所有方法變成了繼承實現了介面方法的抽象類(adapter),然後再實 ...
  • 公司應用項目在客戶部署時經常遇到此類問題,為避免實施部署時增加配置量,花了點時間找到了此問題的終極解決辦法(方案二、修改org.hibernate.hql.ast.HqlLexer的源代碼)。在此進行記錄本問題的分析解決方案。 一、問題現象描述: 1、異常信息: 'weblogic.kernel.D ...
  • 原文轉自:http://www.zccode.com/thread-724-1-1.html 該資源說明:看起來不錯的一套一元雲購CMS源碼,源碼包裡面帶了安卓和ios手機客戶端,手機客戶端需要自己反編譯。 這裡不做功能和其它更多的介紹,可以自己下載後慢慢測試瞭解。安裝說明:伺服器空間需要支持PHP ...
  • 問題的提出整個WR的ISE工程比較大,編譯時間很長,導致開發效率低。通過分析發現,ISE在綜合的時候大量的時間都花在了初始化DPRAM上。調研發現Xilinx提供了BMM文件和DATA2MEM工具,可以將軟核CPU的運行代碼在HDL綜合完後再與bit文件合併,這樣可以節約大量的編譯時間。但是在wr工 ...
  • Atitit.android jsbridge v1新特性 1. Java代碼調用js並傳參其實是通過WebView的loadUrl方法去調用的、只是參數url的寫法不一樣而已1 2. 三、JAVA和JS交互註意事項1 3. Js調用android java通過jsbridge2 4. JsBrid ...
  • 介紹 智能企業(intelligent enterprise)就是全面運用智能管理體系,實現企業管理中“機要素智能化高效整合併實現人機協調”的企業。信息管理中經常談到“人機協調”的問題.這裡所說的“人機協調含義有所不同。信息管理中的人機協調更多的是研究技術上的問題,這裡的人機協調強調的是管理問題,必... ...
  • 序言 這個AOP要從我們公司的一個事故說起,前段時間公司的系統突然在烏雲中出現,數據被泄露的一覽無餘,烏雲上顯示是SQL註入攻擊。呵,多麼貼近生活的一個露洞,可謂是人盡皆知啊。然而卻華麗麗的給拉我們一記耳光。 那麼問題既然來啦,我們.net組有40-50個項目之多吧,怎麼去一一補救這一過失呢?什麼又 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...