C# Devexpress GridControl主从表设置不同视图并展开(数据源为DataTable)

本文介绍如何在DevexpressGridControl中设置主从表的显示,通过在dataset中定义主从表关系,并利用gridView1_MasterRowGetRelationName事件指定子视图级别名称,实现子表按对应视图展开。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.先获取主从表的数据,并在dataset中指定主从表的关系Relations。

product为主表,productde为从表。

    DataSet dt = new DataSet();
    private void Grid_Load(object sender, EventArgs e)
    {
        SqlConnection main=GetSqlConnection();
        new SqlDataAdapter("SELECT p_code,p_name,p_dw,size,color FROM product WHERE LEN(p_code)=3", main).Fill(dt,"product");
        new SqlDataAdapter("SELECT SUBSTRING(p_code,1,3)'fl',p_code,p_name,p_dw,size,color FROM product WHERE LEN(p_code)=6", main).Fill(dt, "productde");
        dt.Relations.Add("详细信息", dt.Tables[0].Columns["p_code"], dt.Tables[1].Columns["fl"]);
        gridControl1.DataSource = dt.Tables[0];
        product.SetMasterRowExpanded(0, true);
    }

2.在主视图的gridView1_MasterRowGetRelationName事件中将e.RelationName = "level1"属性设置为指定的子视图级别名称即可展开子表时按对应的视图展开。

这里我主表使用girdview进行显示,子表使用layoutview进行展开。

private void gridView1_MasterRowGetRelationName(object sender, MasterRowGetRelationNameEventArgs e)
        {
                e.RelationName = "level1";
        }

效果图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不知名君

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值