Devexpress xtransport绑定多个列表数据源
本文关键字:列表 数据源 xtransport 绑定 Devexpress | 更新日期: 2023-09-27 18:11:09
我将class Detail作为我的数据源附加到报告;
class Detail
{
public string Name { get; set; }
public string State { get; set; }
public string City { get; set;}
public List<Transaction> tran { get; set; }
}
class Transaction
{
public string TransactionDate { get; set; }
public string TransactionDescription { get; set; }
}
,在我的查询中,我把它作为列表发送。
public List GetAccount(string account) {
List detail = new List();
sql ....
foreach (DataRow dr in dt.Rows)
{
detail.Add(new Detail()
{
Name= dr["name"].Equals(DBNull.Value) ? string.Empty : dr["name"].ToString(),
.....
tran = GetTransactionDetail(account)// calling a list
});
}
return detail;
}
public List<Transaction> GetTransactionDetail(string account)
{
....
}
和form .cs
XtraReport1 rep = new XtraReport1();
printControl1.PrintingSystem = rep.PrintingSystem;
var ls = query.GetAccount(accountNo);
rep.DataSource = ls;
rep.CreateDocument();
在报告的中,我应该得到事务详细信息的列表,但我只得到第一行。谢谢你,
这取决于您的报表是如何设计的。通常你需要一个单独的波段(DetailReport)来显示所有的细节(如果你使用XRTable)。
先生,您应该使用DataSet
和query.GetAccount(accountNo)
返回DataTable
然后像这样试试。
XtraReport1 rep = new XtraReport1();
printControl1.PrintingSystem = rep.PrintingSystem;
var ds = new ds("TestDataSet");
var ls = query.GetAccount(accountNo);
ds.Tables.Add(ls);
rep.DataSource = ds;
rep.DataMember = ls.TableName;
rep.CreateDocument();