前文介绍了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(); }