data:image/s3,"s3://crabby-images/f132d/f132d3e758d04b391496d1c49b61ec1b06b2b4e2" alt=""
xtraGrid 本身支持DataSet master/detail的数据直接帮定.可以参看其文档,
当然也可以继承接口:
DevExpress.Data.IRelationList 定义自己的数据源.
还有可以动态来帮定detail的数据.- 通过事件触发的方式.
根据今天我的探索,写一点动态帮定经验.
我有两个实体类
1. orderItem 继承了myCollectionBase(来之于CollectionBase)
2. item (明细类)
[DBTableAttr("SalesOrder")]
public class orderItem : myCollectionBase
data:image/s3,"s3://crabby-images/89e28/89e2809954f87bf8972e7757575c3972a20392f6" alt=""
{
public orderItem()
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
}
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
public bool FoundFlag
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
get
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
if (this.Count > 0)
return true;
else
return false;
}
}
[DBColumnAttr("ordersn")]
public String OrderSn
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _orderSn; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _orderSn = value; }
}
[DBColumnAttr("OrderApplyDate")]
public Object OrderApplyDate
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _orderApplyDate; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _orderApplyDate = value; }
}
[DBColumnAttr("DeliveryLocation")]
public String DeliveryLocation
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _deliveryLocation; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _deliveryLocation = value; }
}
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
private String _orderSn ="";
private Object _orderApplyDate;
private String _deliveryLocation ="";
//private bool _foundFlag = false;
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
data:image/s3,"s3://crabby-images/fd876/fd8769e75d0ed0e0d54712dacd6c36a9cc391555" alt=""
class item#region class item
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
[DBTableAttr("SalesOrder_Detail")]
public class item
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
[DBColumnAttr("OrderItemId")]
public int OrderItemId
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _orderItemId; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _orderItemId = value; }
}
[DBColumnAttr("OrderSn")]
public String OrderSn
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _orderSn; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _orderSn = value; }
}
[DBColumnAttr("ProductMaterialCode")]
public String ProductMaterialCode
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _productMaterialCode; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _productMaterialCode = value; }
}
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
[DBColumnAttr("ProductName")]
public String ProductName
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _productName; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _productName = value; }
}
[DBColumnAttr("ProductSpec")]
public String ProductSpec
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _productSpec; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _productSpec = value; }
}
[DBColumnAttr("Qty")]
public int Qty
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _qty; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _qty = value; }
}
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
[DBColumnAttr("SuggestionDeliveryDate")]
public Object SuggestionDeliveryDate
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _suggestionDeliveryDate; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _suggestionDeliveryDate = value; }
}
[DBColumnAttr("ConfirmDate")]
public Object ConfirmDate
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _confirmDate; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _confirmDate = value; }
}
[DBColumnAttr("IsConfirm")]
public bool IsConfirm
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _isConfirm; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _isConfirm = value; }
}
[DBColumnAttr("Confirmer")]
public String Confirmer
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
{
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
get
{ return _confirmer; }
data:image/s3,"s3://crabby-images/cb151/cb15131837b7573e102657052049615e70053792" alt=""
set
{ _confirmer = value; }
}
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
private int _orderItemId;
private String _orderSn;
private String _productMaterialCode;
private String _productName;
private String _productSpec;
private int _qty;
private Object _suggestionDeliveryDate;
private Object _confirmDate;
private bool _isConfirm;
private String _confirmer;
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
}
#endregion
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
}
master的数据源也是一个myCollection对象 : _orders
//获取并帮定master数据源的代码
try
data:image/s3,"s3://crabby-images/89e28/89e2809954f87bf8972e7757575c3972a20392f6" alt=""
{
orderItem ot = _orderBiz.GetOrderInfoByOrderSn(ordersn, true);
_orders.Add(ot);
//MessageBox.Show(_orders.Count.ToString());
gridControl1.DataSource = _orders;
gridControl1.RefreshDataSource();
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
}
catch (Exception ex)
data:image/s3,"s3://crabby-images/89e28/89e2809954f87bf8972e7757575c3972a20392f6" alt=""
{
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
MessageBox.Show(String.Format(" 出错: {0}",ex.Message) );
}
detail数据源则是_orders[i] ,它本身也是一个Collection对象.
先用设计器把想显示的数据列设计好
data:image/s3,"s3://crabby-images/86ea7/86ea7eb30e8c4a663228cfbbdcbb157ebfd6fbcb" alt=""
gridControls 都必然有一个MainView,主视图,你可以通过设计器修改主视图,我就设定gridView1为它的主视图(见上图).
接着通过Create a new level 来创建一个新级别,所有的级别都比MainView至少低一个级别.
我把第二级别定义为orderItems而它使用orderDetail视图来实现数据.
MasterRowGetRelationCount 这个事件只要定义e.RelationCount = 2; 就可以了,这样在界面上才可以看到数据前有+号.
这个事件主要是定义gridView1的关联级别是那一个(注意是orderItems,而不是orderDetail)
private void gridView1_MasterRowGetRelationName(object sender, DevExpress.XtraGrid.Views.Grid.MasterRowGetRelationNameEventArgs e)
data:image/s3,"s3://crabby-images/89e28/89e2809954f87bf8972e7757575c3972a20392f6" alt=""
{
e.RelationName = "orderItems";
}
data:image/s3,"s3://crabby-images/8ac1b/8ac1b1d9e43d9d969d5a6fc827749b39f79c0642" alt=""
private void gridView1_MasterRowGetChildList(object sender, DevExpress.XtraGrid.Views.Grid.MasterRowGetChildListEventArgs e)
data:image/s3,"s3://crabby-images/89e28/89e2809954f87bf8972e7757575c3972a20392f6" alt=""
{
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
e.ChildList = (Fiberxon.DataAccess.myCollectionBase)_orders[gridView1.GetDataSourceRowIndex(e.RowHandle)];
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
//为什么不是下面这个?大家考虑一下(提示:排序
.)
// e.ChildList = (Fiberxon.DataAccess.myCollectionBase)_orders[e.RowHandle];
data:image/s3,"s3://crabby-images/04b01/04b01981f2bc2af4b8078652111c6d3f01535ba8" alt=""
}
private void gridView1_MasterRowEmpty(object sender, DevExpress.XtraGrid.Views.Grid.MasterRowEmptyEventArgs e)
data:image/s3,"s3://crabby-images/89e28/89e2809954f87bf8972e7757575c3972a20392f6" alt=""
{
//没有这个,则+号是虚的,无法点开
e.IsEmpty = false;
}
完成了.运行试试看.