net做数据透视表效果.asp

本文给大家带来的教程是使用asp.net做数据透视表功能,也就是数据三维视图效果,有点复杂,不过效果很帅,这里为你提供一个非常有用的工具创建简单和高级的数据透视表。目标是:我们想要有能力将datatable中的二维的数据转换成三维视图。在大多数情况下,你会从数据库的查询数据填充数据表,例如Code[http://www.xueit.com]SELECTSalesPeople.FullNameAS[SalesPerson],Products.FullNameAS[Product],SUM(Sales.SalesAmount)AS[SaleAmount],SUM(Sales.Qty)AS[Quantity]FROMSalesJOINSalesPeopleWITH(NOLOCK)ONSalesPeople.SalesPersonID=Sales.SalesPersonIDJOINProductsWITH(NOLOCK)ONProducts.ProductCode=Sales.ProductCodeGROUPBYSalesPeople.FullName,Products.FullName该查询会产生下面的数据表:SalesPersonProductQuantitySaleAmountJohnPens200350JohnPencils400500JohnNotebooks100300---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---JohnRulers50100JohnCalculators1201200JohnBackPacks751500JanePens225393.75JanePencils335418.75JaneNotebooks200600JaneRulers75150JaneCalculators80800JaneBackPacks971940---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---SallyPens202353.5SallyPencils303378.75SallyNotebooks198600SallyRulers98594SallyCalculators80800SallyBackPacks1012020SarahPens112196SarahPencils245306.25SarahNotebooks198---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---594SarahRulers50100SarahCalculators66660SarahBackPacks502020正如你所看到的,这是一个二维表,它不是一个非常有用的报表。因此,我们得改变,将它变成更可读的数据表。数据透视表有3个面。X轴构成了在表格上方的大标题。Y轴构成表的左栏,Z轴构成了X轴和Y轴对应的值。简单的数据透视表将会对每一个x轴值都只有一个z轴列,高级的数据透视表将对于每个X轴的值会对应有多个Z轴的值。一个非常重要的一点是,Z轴的值只能是数字。这是因为Z轴值为横轴和纵轴的总额。使用一个非数值Z轴字段将抛出一个异常。文章来自学IT网:http://www.xueit.com/asp.net/show-5418-1.aspx因此,如果你注意上面的数据表,你会发现,“SalesPerson”和“Product”字段可以分配到的X轴或Y轴,但不能给z轴。在“Quantity”和“SaleAmount”字段可以被分配到z轴。Pivot类将数据表转换成htmltable。然后您可以将它输出到Web窗体上。那么,这只是实现的方法。如果你愿意,你可以根据这个类的逻辑创建一个用户控件。Code[http://www.xueit.com]---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---#regionVariablesprivateDataTable_DataTable;privatestring_CssTopHeading;privatestring_CssSubHeading;privatestring_CssLeftColumn;privatestring_CssItems;privatestring_CssTotals;privatestring_CssTable;#endregionVariables#regionConstructorspublicPivot(DataTabledataTable){Init();_DataTable=dataTable;}#endregionConstructors这部分的代码是非常自我解释。你能创建一个Pivot对象,通过传递一个datatable作为参数。在init()方法只分配一个空字符串值给CSS变量。如果CSS的变量是一个空字符串,构造方法将使用默认的样式。每一个CSS变量都有一个相应的属性。Code[http://www.xueit.com]privatestringFindValue(stringxAxisField,stringxAxisValue,stringyAxisField,stringyAxisValue,stringzAxisField){stringzAxisValue="";try{foreach(DataRowrowin_DataTable.Rows){if(Convert.ToString(row[xAxisField])==xAxisValue&&Convert.ToString(row[yAxisField])==yAxisValue){zAxisValue=Convert.ToString(row[zAxisField]);break;}}}catch{throw;}returnzAxisValue;}在FindValue(...)方法在数据表中搜索的对应x轴和y轴值的Z轴值。xAxisField是X轴---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---字段的列名(例如“Product”),而xAxisValue是在该列的值。...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供参考,付费前请自行鉴别。
3、如文档内容存在侵犯商业秘密、侵犯著作权等,请点击“举报”。

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

客服邮箱:

biganzikefu@outlook.com

所有的文档都被视为“模板”,用于写作参考,下载前须认真查看,确认无误后再购买;

文档大部份都是可以预览的,笔杆子文库无法对文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;

文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为依据;

如果您还有什么不清楚的或需要我们协助,可以联系客服邮箱:

biganzikefu@outlook.com

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

确认删除?