DataList和DataGrid嵌套使用问题
在一个DataList里嵌套一个DataGrid,数据库用的是ORACLE
编译是通过的,一浏览ASPX就提示:
编译错误
编译器错误信息: CS0118: “System.Data.DataRowView”表示“类”,此处应为“变量”
ASPX代码:
<form id="Form1" method="post" runat="server">
<asp:DataList ID="ParentDataList" Runat="server" RepeatColumns="3">
<ItemTemplate>
<table>
<tr>
<td colspan="2"><%#DataBinder.Eval(Container.DataItem,"cardTypeName")%></td>
</tr>
<tr>
<td><img src="<%#DataBinder.Eval(Container.DataItem,"cardtypeurl")%>"></td>
<td>
<asp:DataGrid id="SonDataGrid" runat="server" AutoGenerateColumns="False" BorderColor="#33FF33" DataKeyField="cardTypeID" DataSource='<%# Ctype(Container.DataItem,DataRowView).CreateChildView("CardTypeRelation") %>'>
<Columns>
<asp:BoundColumn DataField="cardsubtypename"></asp:BoundColumn>
<asp:BoundColumn DataField="totalVB"></asp:BoundColumn>
</Columns>
</asp:DataGrid>
</td>
</tr>
</table>
</ItemTemplate>
</asp:DataList>
</form>
CS代码:
public class CardTypeShow : System.Web.UI.Page
{
protected System.Web.UI.WebControls.DataList ParentDataList;
protected System.Data.DataSet objDs;
protected string listCout;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
listCout="10";
objDs=new DataSet();
GetDate();
ParentDataList.DataSource=objDs.Tables["cardname"].DefaultView;
ParentDataList.DataBind();
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.ParentDataList.ItemDataBound += new System.Web.UI.WebControls.DataListItemEventHandler(this.ParentDataList_ItemDataBound);
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
private void GetDate()
{
DatabasePool datepool=new DatabasePool();
string sSql = "select * from ( select * from vbcardtype) where rownum<"+listCout;
OracleDataAdapter objAdapter=new OracleDataAdapter(sSql,datepool.Open());
objAdapter.Fill(objDs,"cardname");
sSql="select * from vbcardsubtype where cardtypeid in ";
sSql+=" (select * from ( select cardtypeid from vbcardtype) where rownum<"+listCout+")";
objAdapter.SelectCommand.CommandText=sSql;
objAdapter.Fill(objDs,"cardlist");
datepool.Close();
datepool.Dispose();
DataColumn Parent = objDs.Tables["cardname"].Columns["cardTypeID"];
DataColumn Child = objDs.Tables["cardlist"].Columns["cardTypeID"];
objDs.Relations.Add("CardTypeRelation",Parent,Child);
}
}
private void ParentDataList_ItemDataBound(object sender, System.Web.UI.WebControls.DataListItemEventArgs e)
{
}
///////////////////
那位大哥能告诉我是那里写的不对