DataList和DataGrid嵌套使用问题

huiqi2001 2004-11-10 09:48:05
在一个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)
{

}
///////////////////

那位大哥能告诉我是那里写的不对
...全文
126 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
webdiyer 2004-11-10
  • 打赏
  • 举报
回复
http://www.dotnetjunkies.com/Tutorial/841522C9-FFBD-4C57-BD48-F62B55057FF3.dcik

或者用这个控件:

http://www.denisbauer.com/ASPNETControls/HierarGrid.aspx
huiqi2001 2004-11-10
  • 打赏
  • 举报
回复
谢谢大家,

顺便再问一句,如果在ItemDataBound事件里对内嵌GRID进行绑定,效率是不是比这个要低一些?

我想如果是重新从数据库里取,肯定是慢的。

如果直接从DATASET里取子表对应数据,该怎么写呢?
sukey00 2004-11-10
  • 打赏
  • 举报
回复
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;

namespace wt2004net
{
/// <summary>
/// datalist1 的摘要说明。
/// </summary>
public class datalist : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Repeater parentRepeater;
public datalist()
{
Page.Init += new System.EventHandler(Page_Init);
}
public void Page_Load(object sender, EventArgs e)
{
//Create the connection and DataAdapter for the Authors table.
SqlConnection cnn = new SqlConnection("server=(local);database=pubs; uid=sa;pwd=127509127509 ;");
SqlDataAdapter cmd1 = new SqlDataAdapter("select * from authors",cnn);

//Create and fill the DataSet.
DataSet ds = new DataSet();
cmd1.Fill(ds,"authors");

//Create a second DataAdapter for the Titles table.
SqlDataAdapter cmd2 = new SqlDataAdapter("select * from titleauthor",cnn);
cmd2.Fill(ds,"titles");

//Create the relation bewtween the Authors and Titles tables.
ds.Relations.Add("myrelation",
ds.Tables["authors"].Columns["au_id"],
ds.Tables["titles"].Columns["au_id"]);

//Bind the Authors table to the parent Repeater control, and call DataBind.
parentRepeater.DataSource = ds.Tables["authors"];
Page.DataBind();

//Close the connection.
cnn.Close();
}
private void Page_Init(object sender, EventArgs e)
{
InitializeComponent();
}
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);
}

}
}
shoutor 2004-11-10
  • 打赏
  • 举报
回复
可以动态给datagrid设置数据源,方法写在codebehind中(public),接受datalist传递的参数
penning 2004-11-10
  • 打赏
  • 举报
回复
错了
'<%# ((DataRowView)Container.DataItem).CreateChildView("CardTypeRelation") %>'
penning 2004-11-10
  • 打赏
  • 举报
回复
另外<%# Ctype(Container.DataItem,DataRowView).CreateChildView("CardTypeRelation") %>'是VB的写法,改成(DataRowView).Container.DataItem.CreateChildView["CardTypeRelation"]
penning 2004-11-10
  • 打赏
  • 举报
回复
在ASPX页面加上
<%@ Import namespace=" System.Data"%>
huiqi2001 2004-11-10
  • 打赏
  • 举报
回复
UP
520NET 2004-11-10
  • 打赏
  • 举报
回复
LG

62,047

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧