在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<int>("ID") == table2ID);row.Cells["Info"].Value = info?["Info"];}};通过以上步骤,就可以将两个表绑定到两个DataGridView控件上,并实现两个表之间的关联显示。

