我有一个带有以下代码的嵌套数据网格:
<asp:DataGrid ID="QuotesGrid" Runat="server" AutoGenerateColumns="False" PageSize="1" AllowPaging="True">
<Columns>
<asp:BoundColumn DataField="QuoteNum" SortExpression="QuoteNum" HeaderText="Quote Number">
</asp:BoundColumn>
<asp:BoundColumn DataField="TerritoryTerritoryDesc" SortExpression="Territory" HeaderText="Sales Territory">
</asp:BoundColumn>
<asp:BoundColumn DataField="DueDate" SortExpression="DueDate" HeaderText="Due Date">
</asp:BoundColumn>
<asp:BoundColumn DataField="BTCustID" SortExpression="BTCustID" HeaderText="Customer ID">
</asp:BoundColumn>
<asp:BoundColumn DataField="CustomerName" SortExpression="CustomerName" HeaderText="Customer Name">
</asp:BoundColumn>
<asp:BoundColumn DataField="QuoteAmt" SortExpression="QuoteAmt" HeaderText="Total Quote Value">
</asp:BoundColumn>
<asp:TemplateColumn HeaderText="Quote Lines">
<ItemTemplate>
<asp:DataGrid ID="QuoteLines_Grid" Runat="server" AllowPaging="False" AllowSorting="False" AutoGenerateColumns="False"
ShowHeader="False">
<Columns>
<asp:BoundColumn DataField="QuoteLine" HeaderText="Line Number"></asp:BoundColumn>
<asp:BoundColumn DataField="PartNum" HeaderText="Part Number"></asp:BoundColumn>
<asp:BoundColumn DataField="LineDesc" HeaderText="Line Description"></asp:BoundColumn>
</Columns>
</asp:DataGrid>
</ItemTemplate>
</asp:TemplateColumn>
</Columns>
<PagerStyle HorizontalAlign="Center" ForeColor="#330099" BackColor="#FFFFCC" Mode="NumericPages">
</PagerStyle>
</asp:DataGrid>
我的代码背后如下所示:
DataSet dsQuote = new DataSet("dsQuote");
DataTable dtQuoteHed = new DataTable("dtQuoteHed");
dtQuoteHed.Columns.Add("QuoteNum", typeof(int));
dtQuoteHed.Columns.Add("QuoteLine", typeof(int));
dtQuoteHed.Columns.Add("TerritoryTerritoryDesc", typeof(string));
dtQuoteHed.Columns.Add("DueDate", typeof(DateTime));
dtQuoteHed.Columns.Add("BTCustID", typeof(string));
dtQuoteHed.Columns.Add("CustomerName", typeof(string)); dtQuoteHed.Columns.Add("QuoteAmt", typeof(decimal));
dtQuoteHed.PrimaryKey = new DataColumn[] { dtQuoteHed.Columns["QuoteNum"] };
DataTable dtQuoteDtl = new DataTable("dtQuoteDtl");
dtQuoteDtl.Columns.Add("QuoteNum", typeof(int));
dtQuoteDtl.Columns.Add("QuoteLine", typeof(int));
dtQuoteDtl.Columns.Add("PartNum", typeof(string));
dtQuoteDtl.Columns.Add("LineDesc", typeof(string));
dtQuoteDtl.PrimaryKey = new DataColumn[] { dtQuoteDtl.Columns["QuoteNum"], dtQuoteDtl.Columns["QuoteLine"] };
dsQuote.Tables.AddRange(new DataTable[] { dtQuoteHed, dtQuoteDtl });
dsQuote.Relations.Add(new DataRelation("relQuoteHedtoQuoteDtl", dtQuoteHed.Columns["QuoteNum"], dtQuoteDtl.Columns["QuoteNum"]));
//FILL THE DATASET - ROWS HAVE BEEN VALIDATED
DataGrid DataG = (DataGrid)this.FindControl("QuotesGrid");
DataG.ItemDataBound += new DataGridItemEventHandler(this.OnMainGridDataBound);
DataG.DataSource = dsQuote.Tables["dtQuoteHed"];
dsQuote.WriteXmlSchema("C:\\test.xml");
DataG.DataBind();
//EVENT HANDLER
private void OnMainGridDataBound(object sender, DataGridItemEventArgs e)
{
if (e.Item.ItemType == ListItemType.AlternatingItem || e.Item.ItemType == ListItemType.Item)
{
DataGrid obCtl = (DataGrid)e.Item.FindControl("QuoteLines_Grid");
if (null != obCtl && obCtl is DataGrid)
{
obCtl.DataSource = dsQuote.Tables["dtQuoteDtl"].Select("QuoteNum=" + ((DataRowView)e.Item.DataItem).Row["QuoteNum"]);
obCtl.DataMember = "dtQuoteDtl";
obCtl.DataBind(); // THIS IS WHERE I GET THE ERROR! - COLUMN EXISTS!!
}
}
}
//这是XML
<?xml version="1.0" standalone="yes"?>
<xs:schema id="dsQuote" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xs:element name="dsQuote" msdata:IsDataSet="true" msdata:UseCurrentLocale="true">
<xs:complexType>
<xs:choice minOccurs="0" maxOccurs="unbounded">
<xs:element name="dtQuoteHed">
<xs:complexType>
<xs:sequence>
<xs:element name="QuoteNum" type="xs:int" />
<xs:element name="TerritoryTerritoryDesc" type="xs:string" minOccurs="0" />
<xs:element name="DueDate" type="xs:dateTime" minOccurs="0" />
<xs:element name="BTCustID" type="xs:string" minOccurs="0" />
<xs:element name="CustomerName" type="xs:string" minOccurs="0" />
<xs:element name="QuoteAmt" type="xs:decimal" minOccurs="0" />
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="dtQuoteDtl">
<xs:complexType>
<xs:sequence>
<xs:element name="QuoteNum" type="xs:int" />
<xs:element name="QuoteLine" type="xs:int" />
<xs:element name="PartNum" type="xs:string" minOccurs="0" />
<xs:element name="LineDesc" type="xs:string" minOccurs="0" />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:choice>
</xs:complexType>
<xs:unique name="Constraint1" msdata:PrimaryKey="true">
<xs:selector xpath=".//dtQuoteHed" />
<xs:field xpath="QuoteNum" />
</xs:unique>
<xs:unique name="dtQuoteDtl_Constraint1" msdata:ConstraintName="Constraint1" msdata:PrimaryKey="true">
<xs:selector xpath=".//dtQuoteDtl" />
<xs:field xpath="QuoteNum" />
<xs:field xpath="QuoteLine" />
</xs:unique>
<xs:keyref name="relQuoteHedtoQuoteDtl" refer="Constraint1">
<xs:selector xpath=".//dtQuoteDtl" />
<xs:field xpath="QuoteNum" />
</xs:keyref>
</xs:element>
</xs:schema>
在所选数据源中找不到名为“QuoteLine”的字段或属性。 图片链接:data source error
但我已经验证该字段存在。
图片链接:Column Debug
正如您所看到的,我甚至在数据表dtQuoteHed中添加了“QuoteLine”字段,但这没有任何区别......
有人在我出错的地方有任何想法吗?
非常感谢!
答案 0 :(得分:0)
看看这部分:
DataTable dtQuoteHed = new DataTable("dtQuoteHed");
dtQuoteHed.Columns.Add("QuoteNum", typeof(int));
dtQuoteHed.Columns.Add("QuoteLine", typeof(int));
您正在为Quoteline
表定义dtQuoteHed
列,但在架构dtQuoteHed
元素中没有Quoteline
子元素。因此,请将其从dtQuoteHed
数据表中删除:
DataSet dsQuote = new DataSet("dsQuote");
DataTable dtQuoteHed = new DataTable("dtQuoteHed");
dtQuoteHed.Columns.Add("QuoteNum", typeof(int));
dtQuoteHed.Columns.Add("TerritoryTerritoryDesc", typeof(string));
dtQuoteHed.Columns.Add("DueDate", typeof(DateTime));
dtQuoteHed.Columns.Add("BTCustID", typeof(string));
dtQuoteHed.Columns.Add("CustomerName", typeof(string));
dtQuoteHed.Columns.Add("QuoteAmt", typeof(decimal));
dtQuoteHed.PrimaryKey = new DataColumn[] { dtQuoteHed.Columns["QuoteNum"] };