• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C#教程 > C# ComboBox的联动操作(三层架构)

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

作者:天尽头的那片海 字体:[增加 减小] 来源:互联网 时间:2017-05-28

天尽头的那片海 通过本文主要向大家介绍了马桶c的个人空间,c语言,欲情 c max,维生素c,奔驰c200等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

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

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

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

  
  

  
 }
}

</div>

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

  
 }
}

</div>

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
  }

</div>

其中在使用

获得年级下拉框隐藏值得方法(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

</div>

这是就会出现下面错误:

在年级的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("出错");
   }

</div>

以上就是本文的全部内容,希望对大家学习C#程序设计有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C#利用ReportViewer生成报表
  • C#基于正则去掉注释的方法示例
  • C#中new的用法及与override的区别分析
  • C#实现两个richtextbox控件滚动条同步滚动的简单方法
  • C# for循环的经典案例集锦
  • C#操作word的方法示例
  • C#使用WebClient登录网站并抓取登录后的网页信息实现方法
  • C# WinForm制作异形窗体与控件的方法
  • C#实现Excel表数据导入Sql Server数据库中的方法
  • C#使用NPOI上传excel

相关文章

  • 2017-05-28c# 递归访问文件夹(删掉歌词文件)
  • 2017-05-28C#类的多态性详解
  • 2017-05-28C# DES加密算法中向量的作用详细解析
  • 2017-05-28C#中的递归APS和CPS模式详解
  • 2017-05-28C#常用自定义函数小结
  • 2017-05-28C#实现随鼠标移动窗体实例
  • 2017-05-28c# socket网络编程接收发送数据示例代码
  • 2017-05-28C# 为String类型增加方法详解
  • 2017-05-28C#实现通过程序自动抓取远程Web网页信息的代码
  • 2017-05-28描述C#多线程中lock关键字的使用分析

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法
    • C#中Mutex对象用法分析
    • C#实现把指定数据写入串口
    • C# using三种使用方法
    • 浅析C#数据类型转换的几种形式
    • C# 获取文件夹路径和文件夹包含文件列表
    • C#访问SqlServer设置链接超时的方法
    • C#使用回溯法解决背包问题实例分析
    • C#获取汉字字符串拼音首字母的方法
    • C#使用foreach遍历哈希表(hashtable)的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有