使用XtraGrid实体框架创建主/详细网格

时间:2012-11-08 01:37:34

标签: c# entity-framework grid devexpress master-detail

我是关于C#,实体和使用网格的初学者,所以虽然我认为我所要求的是一般性的,但我有点迷失。 我的SQL数据库中有两个表:PeriodicReportsPeriodicReportGroups。每个报告组可以有一个或多个定期报告,因此我设想的是一个网格,其行在左侧有一个+号,可以展开,显示每个组的相关定期报告。我知道这可以做到,因为我在DevExpress支持网站上看到了非常相似的例子,但是虽然我花时间试图理解它们并将它们应用到我的案例中,但我仍然没有想到如何去做。 这就是我的代码。在我的表中使用实体框架后,该类自动创建:

public partial class ReportEntities : DbContext
{
    public ReportEntities()
        : base("name=ReportEntities")
    {
    }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        throw new UnintentionalCodeFirstException();
    }

    public DbSet<PeriodicReportGroup> PeriodicReportGroups { get; set; }
    public DbSet<PeriodicReport> PeriodicReports { get; set; }
}

我自己创建了这个界面和类,以便只在我的网格中显示某些列:

    public interface IPeriodicReportGroup
{
    string Name { get; }
    string Description { get; }
    bool Active { get; set; }
}

public partial class PeriodicReportGroup : IPeriodicReportGroup
{
}

另一方面,我的XtraForm有XtraGrid:

public partial class Form1 : XtraForm
{
    public Form1()
    {
        InitializeComponent();
        InitSkinGallery();
        InitGrid();
    }

    BindingList<IPeriodicReportGroup> gridDataList = new BindingList<IPeriodicReportGroup>();

    void InitGrid()
    {
        var database = new ReportEntities();

        var reportGroups = database.PeriodicReportGroups.ToList( );

        foreach (var group in reportGroups )
            gridDataList.Add( group );

        gridControl.DataSource = gridDataList;
    }
...

到目前为止,我已成功将我在数据库中定期报告组放入网格中,这很好。但是我仍然不知道如何为每个组扩展细节网格,尽管我觉得它应该是非常标准的东西。任何人都可以提供一些指导吗?我不是要求别人去做我的工作,只是可以指出我正确的方向,因为现在我很丢失。 我还希望能够通过将数据输入空行来添加新的组和新的详细信息,这可能吗?

提前致谢!

1 个答案:

答案 0 :(得分:0)

XtraGrid支持三种方法: 有关详细信息,请查看此link。 基本上主人的细节是混乱的东西,但仔细阅读会帮助你。