当前位置:编程学习 > C#/ASP.NET >>

GridView表格嵌套问题!急!请大家帮忙!

环境:VS.NET2005+C#
目标:想利用GridView实现如下图所示表格嵌套(主表为TEST表(有ID,U_NAME,U_AGE三个字段),成绩一栏对应TEST2表(有ID,NAMES,CHN,ENG四个字段))

编辑思路:
1)创建GridView1,用于接收TEST表数据
2)在GridView1中加入<ItemTemplate>模板,并在<ItemTemplate></ItemTemplate>中添加GridView2,用于接收来自TEST2表 的查询
3)分别创建SQlDataSource1(TEST表的查询)和SqlDataSource2(TEST2表的条件查询)
4)在GridView1的protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)事件中将GridView1的第2列的值传递给SqlDataSource2的参数,作为参数值

代码分别如下,请大家帮我看看....大恩不言谢!
TEST2.ASPX代码如下:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="TEST2.aspx.cs" Inherits="TEST2" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
      <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="Data Source=ADSERVER;Initial Catalog=SZDK;Persist Security Info=True;User ID=sa;Password=62055639" ProviderName="System.Data.SqlClient" SelectCommand="SELECT [ID],[U_NAME],[U_AGE] FROM TEST">
      </asp:SqlDataSource>
      <asp:SqlDataSource ID="SqlDataSource2" runat="server" ConnectionString="Data Source=ADSERVER;Initial Catalog=SZDK;Persist Security Info=True;User ID=sa;Password=62055639" ProviderName="System.Data.SqlClient" SelectCommand="SELECT [ID],[NAMES],[CHN],[ENG] FROM TEST2 WHERE ([NAMES]=?)">
        <SelectParameters>
            <asp:ControlParameter ControlID="GridView1" Name="names" PropertyName="SelectedDataKey"
                Type="String" />
        </SelectParameters>
      </asp:SqlDataSource>
      <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="false"  DataSourceID="SqlDataSource1" DataKeyNames="ID"  AllowPaging="false" AllowSorting="false" PageSize="10" OnRowDataBound="GridView1_RowDataBound" >
        <Columns>
          <asp:BoundField DataField="ID" HeaderText="项次" InsertVisible="False" ReadOnly="True" />
          <asp:BoundField DataField="U_NAME" HeaderText="姓名" InsertVisible="False" ReadOnly="True" />
          <asp:BoundField DataField="U_AGE" HeaderText="年龄" InsertVisible="False" ReadOnly="True" />
          <asp:TemplateField HeaderText="成绩">
            <ItemTemplate>
              <asp:GridView ID="GridView2" runat="server" AutoGenerateColumns="false" DataKeyNames="ID"  AllowPaging="false" AllowSorting="false" PageSize="10">
                <Columns>
                  <asp:BoundField DataField="ID" HeaderText="项次" InsertVisible="false" ReadOnly="true" />
                  <asp:BoundField DataField="NAME" HeaderText="姓名" InsertVisible="false" ReadOnly="true" />
                  <asp:BoundField DataField="CHN" HeaderText="语文" InsertVisible="false" ReadOnly="true" />
                  <asp:BoundField DataField="ENG" HeaderText="英语" InsertVisible="false" ReadOnly="false" />
                </Columns>
              </asp:GridView>
            </ItemTemplate>
          </asp:TemplateField>
        </Columns>
      </asp:GridView>
    </div>
    </form>
</body>
</html>

TEST2.ASPX.CS代码如下:using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class TEST2 : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {

    }
    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            SqlDataSource2.SelectParameters["names"].DefaultValue=e.Row.Cells[1].Text;
            GridView gv = new GridView();
            gv = (GridView)e.Row.FindControl("GridView2");
            gv.DataSource = SqlDataSource2;
            gv.DataBind();
        }
    }
}


--------------------编程问答-------------------- 自己顶....帮帮我啊
补充:.NET技术 ,  C#
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,