博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
为AspxGridView绑定嵌套数据
阅读量:6231 次
发布时间:2019-06-21

本文共 2880 字,大约阅读时间需要 9 分钟。

为AspxGridView绑定嵌套数据
创建时间:2011年11月07日 16:46  阅读次数:(4619)
分享到:
在AspxGridView中允许绑定嵌套数据。也就是一条数据允许再绑定该数据的下级数据。
举个很简单的例子,我们用AspxGridView来显示中国所有省份,然后我们可以为每行数据(每个省)再绑定一个下级数据,也就是每个省对应的所有市的信息,以此类推,我们还可以为每个市再绑定所有县的信息,层层级推。具体展示在页面上就是AspxGridView上的每条数据前面都有一个+号,展开+号,就可以看到下级数据了。
那么应该怎么来绑定嵌套数据呢?
首先要通过设置父AspxGridView的ShowDetailRow=true来开启嵌套。
<SettingsDetail ShowDetailRow="true" / >
子AspxGridView定义在父AspxGridView的<Templates ><DetailRow >标签中。
例:Asp.Net代码
<dxwgv:ASPxGridView ID="MasterGrid" runat="server" KeyFieldName="TaskCode" ClientInstanceName="mastergrid" DataSourceID="SqlDataSource1"  >
<SettingsDetail ShowDetailRow="true" / >
<Columns >
    <dxwgv:GridViewDataColumn Caption="任务编号" FieldName="TaskCode" / >
    <dxwgv:GridViewDataColumn Caption="任务名称" FieldName="TaskName" / >
    <dxwgv:GridViewDataColumn Caption="任务类型" FieldName="TaskType" / >
    <dxwgv:GridViewDataColumn Caption="计划工时" FieldName="PlanHours" / >
    <dxwgv:GridViewDataColumn Caption="计划开始时间" FieldName="PlanBeginDate" / >
    <dxwgv:GridViewDataColumn Caption="计划结束时间" FieldName="PlanEndDate" / >
    <dxwgv:GridViewDataColumn Caption="备注" FieldName="Remark" / >
</Columns >
<Templates >
    <DetailRow >
        <dxwgv:ASPxGridView ID="DetailGrid" runat="server" KeyFieldName="ID" ClientInstanceName="detailgrid" DataSourceID="SqlDataSource2"
         OnBeforePerformDataSelect="DetailGrid_BeforePerformDataSelect" >
            <Columns >
                <dxwgv:GridViewDataColumn Caption="ID" FieldName="ID" / >
                <dxwgv:GridViewDataColumn Caption="任务编号" FieldName="TaskCode" Visible="false" / >
                <dxwgv:GridViewDataColumn Caption="子任务名称" FieldName="ChildTaskName" / >
                <dxwgv:GridViewDataColumn Caption="执行人" FieldName="ExecuteUser" / >
                <dxwgv:GridViewDataColumn Caption="计划工时" FieldName="PlanHours" / >
                <dxwgv:GridViewDataColumn Caption="计划开始时间" FieldName="PlanBeginDate" / >
                <dxwgv:GridViewDataColumn Caption="计划结束时间" FieldName="PlanEndDate" / >
            </Columns >
            <SettingsDetail IsDetailGrid="true" / >
        </dxwgv:ASPxGridView >
    </DetailRow >
</Templates >
</dxwgv:ASPxGridView >
<asp:SqlDataSource
  id="SqlDataSource1"
  runat="server"           
  DataSourceMode="DataSet"
  ConnectionString="数据库连接字符"
  SelectCommand="查询主表数据的SQL语句" >          
</asp:SqlDataSource >
<asp:SqlDataSource
  id="SqlDataSource2"
  runat="server"           
  DataSourceMode="DataSet"
  ConnectionString="数据库连接字符"
  SelectCommand="查询从表数据的SQL语句" >
  <SelectParameters >
    <asp:SessionParameter Name="TaskCode" SessionField="TaskCode" / >
  </SelectParameters >          
</asp:SqlDataSource >
C#代码:
//子AspxGridView数据绑定
protected void DetailGrid_BeforePerformDataSelect(object sender, EventArgs e)
{
    Session["TaskCode"] = (sender as ASPxGridView).GetMasterRowKeyValue();
}
注意C#代码中的DetailGrid_BeforePerformDataSelect方法,该方法是在我们点+号展开数据时执行,GetMasterRowKeyValue()是获取主表中的主键值。因为我们在SqlDataSource2设置了SessionParameter,所以我们在DetailGrid_BeforePerformDataSelect要为SessionParameter赋值。
来源:.net学习网
说明:所有来源为 .net学习网 的文章均为原创,如有转载,请在转载处标注本页地址,谢谢!
【编辑:Wyf】
 

转载于:https://www.cnblogs.com/ydfq-home/p/5017542.html

你可能感兴趣的文章
烂泥:阿里云RDS本地恢复数据
查看>>
php连接oracle测试和pdo连接mysql测试
查看>>
天兔(Lepus)数据库监控系统快速安装部署
查看>>
设置GRUB密码及重置密码
查看>>
使用组策略配置域中计算机系统更新
查看>>
Seam的中文化支持
查看>>
NetBeans 开发 Applet
查看>>
Git学习教程(五):Git标签
查看>>
域环境配置ISA2006企业版存储服务器及NLB之一配置存储服务器
查看>>
[IE 技巧] 显示/隐藏IE 的菜单/工具栏
查看>>
微软私有云分享(R2)2-服务模板的变量
查看>>
足球防守技巧
查看>>
kettle job如何利用java的反射机制获取执行的sql语句
查看>>
SQL 必知必会·笔记<6>使用数据处理函数
查看>>
设计模式:工厂方法模式
查看>>
.Net开发笔记(二十一) 反射在.net中的应用
查看>>
ios31--NSThread
查看>>
设计模式总结篇系列:桥接模式(Bridge)
查看>>
ubuntu VNC连接树莓派
查看>>
[nodemon] Internal watch failed: watch ENOSPC错误解决办法
查看>>