在WinForm中,可以使用DataBinding来绑定两个表。下面是按照步骤来实现的方法:
-
在Visual Studio中创建一个WinForm应用程序。
-
在设计视图中,将两个DataGridView控件拖放到窗体上,分别代表两个表。
-
在代码中,创建两个DataTable对象,分别代表两个表的数据。
DataTable table1 = new DataTable(); DataTable table2 = new DataTable();
- 假设两个表都有一个共同的主键字段,基于这个主键字段可以进行关联。在其中一个表中添加一个外键字段,用于存储另一个表的主键值。
table1.Columns.Add("ID", typeof(int)); table1.Columns.Add("Name", typeof(string)); table1.Columns.Add("Table2ID", typeof(int)); table2.Columns.Add("ID", typeof(int)); table2.Columns.Add("Info", typeof(string));
- 假设表2是表1的从表,通过外键字段将两个表关联起来。在表1和表2中分别添加一些数据。
table1.Rows.Add(1, "John", 1); table1.Rows.Add(2, "Tom", 2); table1.Rows.Add(3, "Lisa", 2); table2.Rows.Add(1, "Info 1"); table2.Rows.Add(2, "Info 2");
- 将两个表分别绑定到DataGridView控件上。
dataGridView1.DataSource = table1; dataGridView2.DataSource = table2;
- 在代码中设置数据绑定。找到DataGridView控件的DataBindingComplete事件,在事件处理程序中实现绑定。
dataGridView1.DataBindingComplete += (sender, e) => { foreach (DataGridViewRow row in dataGridView1.Rows) { int table2ID = Convert.ToInt32(row.Cells["Table2ID"].Value); var info = table2.AsEnumerable().FirstOrDefault(r => r.Field("ID") == table2ID); row.Cells["Info"].Value = https://www.yisu.com/ask/info?["Info"]; } };
通过以上步骤,就可以将两个表绑定到两个DataGridView控件上,并实现两个表之间的关联显示。