XtraGrid Master-Detail 在单独的网格中
Posted
技术标签:
【中文标题】XtraGrid Master-Detail 在单独的网格中【英文标题】:XtraGrid Master-Detail in separate grid 【发布时间】:2012-08-23 08:57:42 【问题描述】:我将 xtragrids 与实体框架一起使用。我有 2 个 sql 表。我在 gridControl1 中显示了合作伙伴表,在 gridControl2 中显示了 partner_contacts 表。如何在 gridControl1 和 gridControl2 之间建立关系。如果我单击 gridControl1 中的一行,我想在 gridControl2 中显示相关行。
第一个表:合作伙伴 - 合作伙伴ID - 合作伙伴名称
第二个表:partner_contacts - partner_contactsId - partner_contactsName - partner_contacts_partner_FK
public partial class frmPartnersList : DevExpress.XtraEditors.XtraForm
ValinorEntities valinor = new ValinorEntities();
public frmPartnersList()
InitializeComponent();
gridControl1.DataSource = valinor.partners;
gridControl2.DataSource = valinor.partner_contacts;
我试过了:
object obj = gridView1.GetRowCellValue(gridView1.GetSelectedRows()[0], gridView1.FocusedColumn.FieldName);
string obj2 = obj.ToString();
var selectedPartner = valinor.partners.Where(p => p.partnerId = obj2).FirstOrDefault();
if (selectedPartner != null)
gridControl2.DataSource = selectedPartner.partner_contacts;
我有 2 个错误:
无法将 lambda 表达式转换为类型“字符串”,因为它不是委托类型
无法将类型“string”隐式转换为“int”
Delegate 'System.Func' 不接受 1 个参数
对于此代码:(p => p.partnerId = obj2)
【问题讨论】:
【参考方案1】:您可以在 gridcontrol1 中使用FocusedRowChanged
事件。
例如当 gridcontrol1 中的焦点行发生变化时
int partnerId=(int)gridview1.GetFocusedRowCellValue("PartnerID");
gridcontrol2.DataSource=valinor.partner_contacts.where(partner_contact=>partner_contact.PartnerId=partnerId);
或者如果您在实体模型中的合作伙伴实体中添加了关系,则
var selectedPartner=valinor.partners.where(p=>p.PartnerId=partnerId).FirstOrDefault();
if(selectedPartner!=null)
gridcontrol2.datasource=selectedPartner.Contacts;
我假设了关系名称...它可能因您的模型而异。
【讨论】:
以上是关于XtraGrid Master-Detail 在单独的网格中的主要内容,如果未能解决你的问题,请参考以下文章