读书人

第一次碰到这么复杂的有关问题

发布时间: 2012-03-04 11:13:33 作者: rapoo

第一次碰到这么复杂的问题
对表a进行自定义统计,行和列都是可以无限选的
行:字段1(一级) 字段2(二级)....
列:字段3(一级) 字段4(二级)....


行头以字段1为例
select distinct 字段1 from a
值1
值2

图中x的等效形式为select x=sum(字段5) from a where 字段1=字段1.值1 and 字段3=字段3.值1 and 字段2=字段2.值2 and 字段4=字段4.值2

求数据查询和表生成的最优解决方案

[解决办法]
= =#看高手答。
[解决办法]
字段1……字段2……看得晕啊……
[解决办法]
用水晶报表 交叉表吧,或者嵌套N个gridview



[解决办法]
mark 帮顶
[解决办法]
等高手来。。
[解决办法]
查询出所有数据 去前台去处理好不好 将处理后的结果填充到表格
[解决办法]

C# code
参考 <asp:GridView ID="GridView1"  OnRowDataBound="GridView1_RowDataBound"  AutoGenerateColumns=false runat="server">      <Columns>        <asp:TemplateField>        <ItemTemplate>            <%#Container.DataItem.ToString()%>               <!--第二层GridView开始-->               <asp:GridView ID="GridView2" OnRowDataBound="GridView2_RowDataBound"   AutoGenerateColumns=false runat="server">                           <Columns>                  <asp:TemplateField>                  <ItemTemplate>                       <%#Container.DataItem.ToString()%>                       <!--第三层GridView开始-->                      <asp:GridView ID="GridView3"  AutoGenerateColumns=false runat=server>                           <Columns>                             <asp:TemplateField>                             <ItemTemplate>                               <%#Container.DataItem.ToString()%>                             </ItemTemplate>                             </asp:TemplateField>                                               </Columns>                        </asp:GridView>                       <!--第三层GridView 结束-->                                          </ItemTemplate>                  </asp:TemplateField>                 </Columns>                </asp:GridView>              <!--第二层GridView结束-->                        </ItemTemplate>          </asp:TemplateField>         </Columns>        </asp:GridView>         <!--第一层GridView结束-->++++++++++.cs代码++++++++++++++++RowDataBound与1.x中的ItemDataBound也有一腿!using System;using System.Data;using System.Configuration;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;using System.Collections;public partial class _Default : System.Web.UI.Page {    protected void Page_Load(object sender, EventArgs e)    {        this.GridView1.DataSource = Al("GridView1Item:");        this.GridView1.DataBind();    }    //DataSource    protected ArrayList Al(string GetStr)    {        ArrayList al = new ArrayList();        for(int i=0;i<2;i++)        {            al.Add(GetStr+i.ToString());        }        return al;    }    //GridView1_RowDataBound    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)    {        if (e.Row.RowType == DataControlRowType.DataRow)        {            GridView gv = (GridView)e.Row.FindControl("GridView2");            gv.DataSource = Al("GridView2Item:");            gv.DataBind();                    }    }    //GridView2_RowDataBound    protected void GridView2_RowDataBound(object sender, GridViewRowEventArgs e)    {        if (e.Row.RowType == DataControlRowType.DataRow)        {            GridView gv = (GridView)e.Row.FindControl("GridView3");            gv.DataSource = Al("GridView3Item:");            gv.DataBind();        }    }} 


[解决办法]
好晕眩啊~~~~~
[解决办法]
............
帮顶,学习下
[解决办法]
试一下楼上的方法
[解决办法]
嵌套控件的方式应该可行· LZ 去试下·
[解决办法]
没理解各字段的关系,楼主能不能说的清楚些。
[解决办法]
很,看明白·~
[解决办法]
好难哦,高手在哪里?
[解决办法]

[解决办法]
晕忽忽~
[解决办法]
关注
[解决办法]
水晶报表的交叉表可以实现的哦
[解决办法]
reporting service啊~~
[解决办法]
关注
[解决办法]

select a.f1,a.f2,sum(col1) 黑上,sum(col2) 黑下,sum(col3) 白上,sum(col4) 白下 from
(
select f1,f2,
case
when f3='黑' and f4='上'
then sum(f5)
end as col1,
case
when f3='黑' and f4='下'
then sum(f5)
end as col2,
case
when f3='白' and f4='上'
then sum(f5)
end as col3,
case
when f3='白' and f4='下'
then sum(f5)
end as col4
from dbo.Table_1
group by f1,f2,f3,f4
) as a
group by a.f1,a.f2
order by f1

男大1234
男小5678
女大9101112
女小13141516


select a.f1,sum(col1)+sum(col2) 黑,sum(col3) +sum(col4) 白 from
(
select f1,f2,
case
when f3='黑' and f4='上'
then sum(f5)
end as col1,
case
when f3='黑' and f4='下'
then sum(f5)
end as col2,
case
when f3='白' and f4='上'
then sum(f5)
end as col3,
case
when f3='白' and f4='下'
then sum(f5)
end as col4
from dbo.Table_1
group by f1,f2,f3,f4
) as a
group by a.f1
order by f1

男1422
女4654

也许不对啊~
[解决办法]
关注
[解决办法]
关注下 貌似比较扰人啊
[解决办法]
用repeater就能做,他是用户自定义界面控件:参考一下我做过的,如下
界面代码:你可以复制过去看一下效果
<div>
<table border="0" cellpadding="0" cellspacing="0" style="width: 884px; height: 288px">
<tr>
<td align="center" style="width: 100%; height: 58px">
<asp:HyperLink ID="HyperLink1" runat="server" Font-Size="14pt" NavigateUrl="~/ShopInfoManage.aspx"
Width="80px">返 回</asp:HyperLink></td>
</tr>
<tr>
<td style="width: 100%">
<asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="Repeater1_ItemDataBound">


<HeaderTemplate>
<table border="1" cellpadding="0" cellspacing="0">
<tr>
<td align="center" rowspan="3" style="width: 100px">
<span>项目</span></td>
<td align="center" colspan="2">
合计</td>
<td align="center" colspan="2">
铁</td>
<td align="center" colspan="4">
钢筋</td>
</tr>
<tr>
<td align="center" style="width: 100px" rowspan="2">
吨</td>
<td align="center" style="width: 100px" rowspan="2">
%</td>
<td align="center" style="width: 100px" rowspan="2">
吨</td>
<td align="center" style="width: 100px" rowspan="2">
%</td>
<td align="center" style="width: 100px" rowspan="2">
吨</td>
<td align="center" style="width: 100px" rowspan="2">
%</td>
<td align="center" colspan="2">
其中</td>
</tr>
<tr>
<td align="center" style="width: 100px">
一等</td>
<td align="center" style="width: 100px">
二等</td>
</tr>
</HeaderTemplate>

<FooterTemplate>
<tr>
<td style="width: 100px">合计</td>
<td align="center" style="width: 100px">
<asp:Label ID="Label10" runat="server" Text=''></asp:Label></td>
<td align="center" style="width: 100px">
<asp:Label ID="Label11" runat="server" Text=''></asp:Label></td>
<td align="center" style="width: 100px">
<asp:Label ID="Label12" runat="server" Text=''></asp:Label></td>
<td align="center" style="width: 100px">
<asp:Label ID="Label13" runat="server" Text=''></asp:Label></td>
<td align="center" style="width: 100px">
<asp:Label ID="Label14" runat="server" Text=''></asp:Label></td>
<td align="center" style="width: 100px">
<asp:Label ID="Label15" runat="server" Text=''></asp:Label></td>
<td align="center" style="width: 100px">
<asp:Label ID="Label16" runat="server" Text=''></asp:Label></td>
<td align="center" style="width: 100px">
<asp:Label ID="Label17" runat="server" Text=''></asp:Label></td>
</tr>
</table>
</FooterTemplate>

<ItemTemplate>


<tr>
<td style="width: 100px">
<asp:Label ID="Label1" runat="server" Text='<% # Bind("ShopID") %>'></asp:Label>
</td>
<td align="center" style="width: 100px">
<asp:Label ID="Label2" runat="server" Text='<% # Bind("ShopCount") %>'></asp:Label>
</td>
<td align="center" style="width: 100px">
<asp:Label ID="Label3" runat="server" Text='<% # Bind("CountCenti") %>'></asp:Label>
</td>
<td align="center" style="width: 100px">
<asp:Label ID="Label4" runat="server" Text='<% # Bind("TT") %>'></asp:Label>
</td>
<td align="center" style="width: 100px">
<asp:Label ID="Label5" runat="server" Text='<% # Bind("TTCenti") %>'></asp:Label>
</td>
<td align="center" style="width: 100px">
<asp:Label ID="Label6" runat="server" Text='<% # Bind("GGCount") %>'></asp:Label>
</td>
<td align="center" style="width: 100px">
<asp:Label ID="Label7" runat="server" Text='<% # Bind("GGCenti") %>'></asp:Label>
</td>
<td align="center" style="width: 100px">
<asp:Label ID="Label8" runat="server" Text='<% # Bind("GG1D") %>'></asp:Label>
</td>
<td align="center" style="width: 100px">
<asp:Label ID="Label9" runat="server" Text='<% # Bind("GG2D") %>'></asp:Label>
</td>
</tr>
</ItemTemplate>
</asp:Repeater>
</td>
</tr>
</table>
</div>
[解决办法]

[解决办法]
帮顶了
[解决办法]
关注
[解决办法]
我有一个类似的问题,期待高手。
[解决办法]
顶一下。
[解决办法]
Pivot表,用于显示多维数据集,要开发这种控件是比较有难度的。
如果可能的话,可以选择使用现有控件
[解决办法]
都是高手啊,领教了...
[解决办法]
哎,貌似好难呢…学习了…
[解决办法]
有创意,呵呵。
[解决办法]
看不懂 顶下
[解决办法]
关注一下
[解决办法]
值得关注!!

[解决办法]
关注
[解决办法]
UP
[解决办法]
值得关注
[解决办法]
关注,正在学sql
[解决办法]
有点看不清楚。。。。。。
[解决办法]
学习一下!
[解决办法]
第一次啊发表啊新人
[解决办法]
hehe
[解决办法]
学习
[解决办法]
fgagagadfasfdasf
[解决办法]
fafagasgafafaffgdfgeger
[解决办法]
asdfasdf
[解决办法]
不晕不行
[解决办法]
这东西我们新手看得头晕了,还要学习中,,,
[解决办法]
不知道楼主有没听说过嵌套查询!
内联,也许可以解决
[解决办法]
学习
[解决办法]
顶一下
[解决办法]
顶一下
[解决办法]
凑个热闹
[解决办法]
不懂哦,学习下
[解决办法]
帮顶起
[解决办法]
学习了,帮顶
[解决办法]
刚好有个借鉴
[解决办法]

[解决办法]
每次都要弄点积分才下载
[解决办法]
今天太累,明天来看看
[解决办法]
不难么?
[解决办法]
恩 学习学习哦

关注中
[解决办法]
路过,呵呵,挺有意思的题目
[解决办法]

探讨
reporting service啊~~

[解决办法]
好复杂!
顶一下

[解决办法]
这个问题有待研究···高深
[解决办法]
学习
[解决办法]
这个问题有待研究···高深


[解决办法]
关注
[解决办法]
lz说,行和列都是可以无限选的

所以还没人答对
[解决办法]
晕! ! 不过帮顶了!
[解决办法]

[解决办法]
有点复杂呀
[解决办法]
mark
[解决办法]
飘过的说
mark
[解决办法]
不会..
[解决办法]
用一个ReportViewer吧,似乎是生成报表的一个强大工具.
给个教程
http://msdn.microsoft.com/zh-cn/library/ms170246.aspx
[解决办法]
关注一下

读书人网 >asp.net

热点推荐