【问题标题】:Tables A DataGridViewComboBoxColumn value displayed in Tables B DataGridViewComboBoxColumn [closed]表 A DataGridViewComboBoxColumn 值显示在表 B DataGridViewComboBoxColumn [关闭]
【发布时间】:2021-05-10 08:08:44
【问题描述】:

是否可以在表 B 的 DataGridViewComboBoxColumn 中显示例如表 A 的 DataGridViewComboBoxColumn 值?

我尝试使用 DataGridViewComboBoxColumn A 的名称(名称定义为 Name = "Something")传递给 DataMember DataGridViewComboBoxColumn "B",但它似乎不起作用,因为它会引发错误,找不到“某事”列。

【问题讨论】:

  • 这不是我在 SO 上看到的最清楚的问题,但我想我明白你想要做什么......
  • 欢迎来到 SO。请参阅minimal reproducible example

标签: c# winforms datagridview combobox datagridviewcomboboxcolumn


【解决方案1】:

场景:

你有这样的表:

Employee
FirstName - e.g. "John"
DepartmentID - e.g. 1 (for Tech)

Department
ID - e.g. 1
Name - e.g. Tech

并且您想要一个带有组合框列的 datagridview 来显示/选择部门

  • 您的 datagridview 已绑定到员工的数据表
  • 您已经创建了一个 datagridviewcomboboxcolumn (DGVCBC)

您应该设置您的 DGVCBC,使其具有:

  • .DataSource = 保存部门数据的数据表
  • .ValueMember = 保存部门 ID 的列的字符串名称(在部门表中),例如在我的示例中为“ID”
  • .DisplayMember = 保存部门名称的列的字符串名称(在部门表中),例如在我的示例中为“ID”
  • .DataMember = 保存员工部门ID的列的字符串名称(例如,在我的示例中为“DepartmentID”)

您可以在设计器或代码中进行此设置。这样设置,DGVCBC 将从 DepartmentID 中读取 id,它会在 departmentDatatable.ID 中查找该 ID,它会在 departmentDatatable.Name 中显示相关名称。当您将组合更改为新值时,它将采用选定的新 ID 值并将其应用于 DepartmentID,从而更改员工的部门

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2010-09-15
    • 1970-01-01
    • 2018-07-14
    • 2017-04-05
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多