我是关于C#,实体和使用网格的初学者,所以虽然我认为我所要求的是一般性的,但我有点迷失。
我的SQL数据库中有两个表:PeriodicReports
和PeriodicReportGroups
。每个报告组可以有一个或多个定期报告,因此我设想的是一个网格,其行在左侧有一个+号,可以展开,显示每个组的相关定期报告。我知道这可以做到,因为我在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;
}
...
到目前为止,我已成功将我在数据库中定期报告组放入网格中,这很好。但是我仍然不知道如何为每个组扩展细节网格,尽管我觉得它应该是非常标准的东西。任何人都可以提供一些指导吗?我不是要求别人去做我的工作,只是可以指出我正确的方向,因为现在我很丢失。 我还希望能够通过将数据输入空行来添加新的组和新的详细信息,这可能吗?
提前致谢!