要实现这种情况,用gridview能实现吗?

stg609 2009-02-18 01:28:07
现在有如下数据:
GROUP | ID | SCORE
A 1 100
B 2 50
A 3 90
B 4 50

现在我想对如上数据按照GROUP分组后,并利用gridview来显示成如下情况:

GROUP | ID | SCORE
A 1 100
A 3 90
合 计       190
B 2 50
B 4 50
合 计       100

要显示成这样,用gridview可以实现吗?如果不能,那该怎么实现呀?
...全文
137 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
去孟子那里看下
chenamo9651 2009-02-18
  • 打赏
  • 举报
回复
可以,也就是控制gridview的格式,你可以到网上看看gridview的控制格式,或者你到网上找找gridview合并单元格之类的的东东!
其实gridview里面的数据,都可以动态控制,gridview很强大,好好研究!
walkghost 2009-02-18
  • 打赏
  • 举报
回复
直接往前台输出table就是了。
koukoujiayi 2009-02-18
  • 打赏
  • 举报
回复
应该是可以的,可以这样:
select [GROUP],ID,SCORE from table where [GROUP]='A'
union
select 'A总计','',sum(SCORE) from table where [GROUP]='A'
union
select * from table where [GROUP]='B'
union
select 'B总计','',sum(SCORE) from table where [GROUP]='B'

显示是:
GROUP | ID | SCORE
A 1 100
A 3 90
A总 计   0    190
B 2 50
B 4 50
B总 计   0    100

在GridView绑定的时候,将0用空格替换,A总计,B总计替换成合计即可!!
我在地球 2009-02-18
  • 打赏
  • 举报
回复
学习
lonelySurvive 2009-02-18
  • 打赏
  • 举报
回复
建立使用用DATALIST,或者reoeater
stg609 2009-02-18
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 xiazhijiang520 的回复:]
自己创建datatable实现这种效果,然后通过gridview帮顶输出!
[/Quote]

用datatable该如何实现,请指教~~
  • 打赏
  • 举报
回复
使用Repeater或者ListView(.net 3.5提供的控件)要比GridView更合适。
泡面之夏 2009-02-18
  • 打赏
  • 举报
回复
ps:程序创建datatable内存表
zzc205 2009-02-18
  • 打赏
  • 举报
回复
在后台把数据排好以后呈现出来,用不用gridview都行。
泡面之夏 2009-02-18
  • 打赏
  • 举报
回复
自己创建datatable实现这种效果,然后通过gridview帮顶输出!
upingking 2009-02-18
  • 打赏
  • 举报
回复
不能,devexpress组件中可以实现,或者自己重新组织datatable,加入合计行,然后绑定到gridview
ASP.NET实现Gridview隐藏/显示列源码 介绍: 这篇文章演示如果让用户有显示/隐藏他们需要的GridView的列的功能,这是非常有用的,因为在GridView的所有列并不是每个的用户都需要的.用户想根据自己的需求看到想要的列.而不是显示一个巨大的gridview,霸占了整个屏幕,而是一个整洁的Gridview,而且它有所有你需要的列.对于页面的打印这也是一个非常有用的技术,因为用户可以灵活地选择GridView的列打印。 背景: RowCreated 和ItemDataBound 事件允许你用多种方式注入HTML, CSS,和JavaScript 来增强GridView 控件的功能。 文章将会演示两种显示和隐藏GridView列的方法,一种是客户端的方法,另外一种是服务段的方法. 在客户段显示和隐藏GridView的列 大部分代码是在GridView的RowCreated事件生成客户端的功能的。当GridView的Header行被创建后,一个带负号的HyperLink被插入每个Header行的单元格中用来隐藏列。 这个hyperlink通过它的onclick事件调用一个HideCol的Javascript方法,CSS类用来增加负号的大小,当每个数据行被创建的时候,一个Id将会被添加到每行中用来让Javascript区分每一行. 代码 protected void GridView1_RowCreated(object sender, GridViewRowEventArgs e) { GridView gridView = (GridView)sender; StringBuilder sb = new StringBuilder(); // For the header row add a link to each header // cell which can call the HideCol javascript method if (e.Row.RowType == DataControlRowType.Header) { // Loop through each cell of the row for (int columnIndex = 0; columnIndex 0) { Label columnTextLabel = new Label(); columnTextLabel.Text = e.Row.Cells[columnIndex].Text; e.Row.Cells[columnIndex].Controls.Add(columnTextLabel); } } } // Give each row an id if (e.Row.RowType == DataControlRowType.Pager) e.Row.Attributes.Add("id", gridView.ClientID + "_pager"); else e.Row.Attributes.Add("id", gridView.ClientID + "_r" + e.Row.RowIndex.ToString()); } SetupShowHideColumns方法中生成“Show Columns”下拉菜单的HTML,输出在Literal控件上面 。 代码 private void SetupShowHideColumns(GridView gridView, Literal showHideColumnsLiteral) { StringBuilder sb = new StringBuilder(); sb.Append(""); sb.Append(""); sb.Append("- Show Column -"); showHideColumnsLiteral.Text = sb.ToString(); } 在数据绑定到GridView之后,其余的工作由ShowHideColumns.js中的javascript来完成.当列头的hyperlink被点击的时候后,它将会传递GridView的名字,列的索引和列名给HideCol方法,这个方法能找到这一列的每个单元格,每个单元格的将添加display:none样式,用来隐藏这一列. 当选择"Show Column"中的选项后,Javascript方法ShowCol将会被调用,它将移除每个单元格的display:none样式,这一列将会被再次显示. 在服务端显示/隐藏GridView的列 服务端的例子将通过RowCreated事件给每个列头添加一个负号,这次是使用LinkButton控件.设置CommandName和CommandArgument属性,这样当通过LinkButton引发RowCommand事件时,相关的列都可以隐藏。以前隐藏的列索引存储在一个List中,这些列在建立时,将会被隐藏的。 代码 protected void GridView1_RowCreated(object sender, GridViewRowEventArgs e) { // For the header row add a link button to each header // cell which can execute a row command if (e.Row.RowType == DataControlRowType.Header) { // Loop through each cell of the header row for (int columnIndex = 0; columnIndex 0) { Label columnTextLabel = new Label(); columnTextLabel.Text = e.Row.Cells[columnIndex].Text; e.Row.Cells[columnIndex].Controls.Add(columnTextLabel); } } } // Hide the column indexes which have been stored in hiddenColumnIndexes foreach(int columnIndex in hiddenColumnIndexes) if (columnIndex 0) { this.GridView1ShowHideColumns.Visible = true; this.GridView1ShowHideColumns.Items.Add(new ListItem("-Show Column-", "-1")); foreach (int i in hiddenColumnIndexes) this.GridView1ShowHideColumns.Items.Add( new ListItem(columnNames[i], i.ToString())); } else { this.GridView1ShowHideColumns.Visible = false; } } 示例项目的例子: 客户端的例子: •C#.NET - Client-side example accessing data stored in session. •C#.NET - Client-side example which includes: MasterPage, UpdatePanel, GridView editing, paging and sorting, accessing data via the SqlDataSource control. •VB.NET - Client-side example accessing data stored in session. 服务端的例子 •C#.NET - Server-side example accessing data stored in session. •C#.NET - Server-side example which includes: MasterPage, UpdatePanel, GridView editing, paging and sorting, accessing data via the SqlDataSource control. •VB.NET - Server-side example accessing data stored in session. 结论: 如果你想让你的用户能够显示和隐藏在ASP.NET GridView的列,那么这种技术可能是非常有用的。 原文:http://www.codeproject.com/KB/webforms/ShowHideGridviewColumns.aspx 作者:朱祁林 出处:http://zhuqil.cnblogs.com/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

62,047

社区成员

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

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

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

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