C# 在dgv1中选择一条数据右击 获取Sn 通过Sn在五个数据库中分别找到相关数据 并组合显示到dgv2
时间: 2024-02-27 21:54:38 浏览: 89
C#实现把dgv里的数据完整的复制到一张内存表的方法
好的,我理解了你的问题。你需要使用 C# 编写程序,实现在 dgv1 中选择一条数据右击获取 Sn,然后在五个数据库中分别查找与该 Sn 相关的数据,并将这些数据组合显示到 dgv2 中。下面是一个大致的实现思路:
1. 在 dgv1 中选中一条数据后,右击菜单中添加一个“获取 Sn”的选项,点击后获取该行中的 Sn 值。
2. 针对五个数据库,分别连接数据库,并构造查询语句,查询与 Sn 相关的数据。
3. 将五个数据库查询出来的数据按照一定的规则进行组合,生成一个新的数据集合。
4. 将生成的数据集合绑定到 dgv2 上显示出来。
下面是一个简单的示例代码,供你参考:
```csharp
// dgv1 行选中事件
private void dgv1_RowHeaderMouseClick(object sender, DataGridViewCellMouseEventArgs e)
{
if (e.Button == MouseButtons.Right)
{
// 获取 Sn 值
string sn = dgv1.Rows[e.RowIndex].Cells["Sn"].Value.ToString();
// 在五个数据库中查找相关数据
List<DataRow> dataList = new List<DataRow>();
for (int i = 1; i <= 5; i++)
{
using (SqlConnection conn = new SqlConnection($"Data Source=Server{i};Initial Catalog=Database{i};Integrated Security=True"))
{
conn.Open();
string sql = $"SELECT * FROM Table{i} WHERE Sn='{sn}'";
SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);
DataTable dt = new DataTable();
adapter.Fill(dt);
foreach (DataRow row in dt.Rows)
{
dataList.Add(row);
}
}
}
// 组合数据
DataTable resultDt = new DataTable();
resultDt.Columns.Add("Sn");
resultDt.Columns.Add("Data1");
resultDt.Columns.Add("Data2");
foreach (DataRow row in dataList)
{
DataRow newRow = resultDt.NewRow();
newRow["Sn"] = row["Sn"];
newRow["Data1"] = row["Data1"];
newRow["Data2"] = row["Data2"];
resultDt.Rows.Add(newRow);
}
// 将数据显示到 dgv2 中
dgv2.DataSource = resultDt;
}
}
```
需要注意的是,这只是一个示例代码,实际应用中还要根据具体情况进行一些优化。
阅读全文