zoukankan      html  css  js  c++  java
  • Winform开发常用控件之DataGridView的简单数据绑定——代码绑定DataSet、DataTable、IList、SqlDataReader

    前文介绍了Winform为DataGridView提供的数据自动绑定功能,下面介绍一下采用代码的数据绑定

    1、用DataSet和DataTable为DataGridView提供数据源

    先上代码

    private void Form1_Load(object sender, EventArgs e)
            {
                String strConn = "Data Source=210.26.*.*;Initial Catalog=Test;User ID=sa;Password=*****";  
                SqlConnection conn = new SqlConnection(strConn);
                String sqlId = "select * from [Student] "; 
                conn.Open(); SqlCommand cmd = new SqlCommand(sqlId, conn); 
                SqlDataAdapter da = new SqlDataAdapter(cmd); 
                DataSet ds = new DataSet();
                da.Fill(ds, "student");            //dataGridView1.DataSource=ds.Tables["Student"];此处直接用DataTalbe绑定,与下面两行代码的效果是一样的
                dataGridView1.DataSource = ds;//使用Dataset,单必须指定DataMember,因为DataSet是DataTable的集合,而datagridview只能绑定一个datatable
                dataGridView1.DataMember = "Student";           
                conn.Close(); 
            }

    这里需要指出的是,如果不对dataGridview做任何设置,上面这段代码将自动将数据绑定到dataGridview上,效果图如下

    这样的显示不是很好,那么我只需要将姓名和住址显示出来怎么办?那就需要设置datagridview的items属性或者datagridview右侧箭头——编辑列

    除了设置HeaderText显示列名外,需要设置DataPropertyName属性必须对应表中的列。

    那这样就可以了吗?NO,这样的话,如果继续运行上面的程序,会出现下图情况

    为什么会这样尼?明明只是指定了绑定两个列的,呵呵还需要在代码里或者属性里设置一下

    dataGridView1.AutoGenerateColumns = false;//此行指定不需要自动绑定数据列,数据列在dataGridView的属性items集合里指定,必须放在绑定数据之前哦,放到后面是没用的

    对,在代码里需要加入此行代码,并且这行代码必须放在dataGridView.DataSource之前,如果放在后面是没用的哦。

    这块儿介绍一个列属性Frozen(冻结)的意思,即如果datagridview有滚动条出现,拉动滚动条时,冻结的列是不会动的,其他的列会跟随滚动条,上个图看看,当拉动滚动条时,住址栏已经隐藏起来了,而姓名栏是冻结列true

    2、使用IList类集合绑定

    我们在软件开发的过程中,有些数据查出来是IList,再转DataTable就比较麻烦了,那么能不能直接绑定IList尼?其实也是可以的,贴一点点代码

     IList<Student> lst = StudentService.GetAllOrderbyNumb();//用Student提供的方法查询到的结果是Ilist
     dataGridView1.DataSource = lst;

    其实就是这么滴简单。

     3、使用SqlDataReader绑定

    使用SqlDataReader绑定需要,现在窗体上放置一个数据源控件BindingSource,上代码

     private void Form1_Load(object sender, EventArgs e)
            {
                String strConn = "Data Source=210.26.*.*;Initial Catalog=Test;User ID=sa;Password=****";  
                SqlConnection conn = new SqlConnection(strConn);
                String sqlId = "select * from [Student] "; 
                conn.Open(); 
                SqlCommand cmd = new SqlCommand(sqlId, conn);              
                SqlDataReader studentlist = cmd.ExecuteReader();
                bindingSource1.DataSource = studentlist;//数据源控件bindingSourse是必须的
                dataGridView1.DataSource = bindingSource1;
                conn.Close(); 
            }
  • 相关阅读:
    最长回文字符(需要补)
    无重复字符的最长子串
    两数之和——链表
    两个数之和
    android 动画基础绘——帧动画(三)
    android 动画基础绘——view 动画(二)[补]
    android 动画基础绘——view 动画
    全国疫情精准定点动态更新(.net core)
    桶排序
    计数排序
  • 原文地址:https://www.cnblogs.com/yieryi/p/4610790.html
Copyright © 2011-2022 走看看