当前位置:首页 > 网络编程 > WEB编程 > ASP.net > ASP.NET数据格中计算数值总和

ASP.NET数据格中计算数值总和

点击次数:14 次 发布日期:2008-11-27 02:21:26 作者:源代码网
源代码网推荐
源代码网推荐  以表格形式显示数据可以带来很多好处。在本文中,我将讲解如何使用DataGrid计算总计,这在处理数值时会经常用到。
源代码网推荐  
源代码网推荐  在讨论DataGrid控制时,常常可以听到别人对此方法的嘲笑。他们常常抛弃它转而使用第三方的工具。事实上,DataGrid作为. NET Framework的核心部分,已成为我开发工具箱中极具价值的工具。
源代码网推荐  
源代码网推荐  什么是总计?
源代码网推荐  在应用程序中使用DataGrid控制可以允许你以对绝大部分用户来说熟悉的格式来发布数据(栅格格式常常被用于如微软Excel等电子数据表格应用程序)。使用此类型的应用程序,用户可以按照习惯查看自定义函数如每栏总计、平均值等。而这些函数并不是DataGrid的标准函数,你可以自行编写代码来轻松地实现这些函数。
源代码网推荐  
源代码网推荐  在本例中,我将使用所有SQL Server版本都可提供的Northwind范例数据库,并从顺序表格中提取数据。我将对货物栏计算总计值,这个总计值应当在DataGrid中一致地显示出来。一下就是此应用程序的C#代码。
源代码网推荐  
源代码网推荐  <%@ Import Namespace="System.Data.SqlClient" %>
源代码网推荐  
源代码网推荐  <%@ Import Namespace="System.Data" %>
源代码网推荐  
源代码网推荐  <%@ Page language="c#" %>
源代码网推荐  
源代码网推荐  <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
源代码网推荐  
源代码网推荐  <HTML><HEAD><title>Builder.com DataGrid Totals Example</title>
源代码网推荐  
源代码网推荐  </HEAD>
源代码网推荐  
源代码网推荐  <body MS_POSITIONING="GridLayout">
源代码网推荐  
源代码网推荐  double totalFreight = 0;
源代码网推荐  
源代码网推荐  private void Page_Load(object sender, System.EventArgs e) {
源代码网推荐  
源代码网推荐  if (!Page.IsPostBack) {
源代码网推荐  
源代码网推荐  BindData();
源代码网推荐  
源代码网推荐  } }
源代码网推荐  
源代码网推荐  private void BindData() {
源代码网推荐  
源代码网推荐  const string sConn;
源代码网推荐  
源代码网推荐  sConn = "server=(local);Initial Catalog=Northwind;UID=ctester;PWD=password";
源代码网推荐  
源代码网推荐  try {
源代码网推荐  
源代码网推荐  SqlConnection conn = new SqlConnection(sConn);
源代码网推荐  
源代码网推荐  conn.Open();
源代码网推荐  
源代码网推荐  string sSQL = "SELECT TOP 10 OrderID, Freight, ShipName, ShipCountry FROM
源代码网推荐  
源代码网推荐   Orders";
源代码网推荐  
源代码网推荐  SqlCommand comm = new SqlCommand(sSQL, conn);
源代码网推荐  
源代码网推荐  SqlDataReader dr = comm.ExecuteReader();
源代码网推荐  
源代码网推荐  dgNorthwind.DataSource = dr;
源代码网推荐  
源代码网推荐  dgNorthwind.DataBind();
源代码网推荐  
源代码网推荐  } catch (Exception e) {
源代码网推荐  
源代码网推荐  Console.WriteLine(e.ToString());
源代码网推荐  
源代码网推荐  } }
源代码网推荐  
源代码网推荐  private void doTotal(object sender, DataGridItemEventArgs e) {
源代码网推荐  
源代码网推荐  if (e.Item.ItemType == ListItemType.Item | e.Item.ItemType ==
源代码网推荐  
源代码网推荐   ListItemType.AlternatingItem) {
源代码网推荐  
源代码网推荐  double currentFreight = Convert.ToDouble(DataBinder._Eval(e.Item.DataItem,
源代码网推荐  
源代码网推荐   "Freight"));
源代码网推荐  
源代码网推荐  totalFreight += currentFreight;
源代码网推荐  
源代码网推荐  } else if (e.Item.ItemType == ListItemType.Footer) {
源代码网推荐  
源代码网推荐  e.Item.Cells[2].Text = "Total:";
源代码网推荐  
源代码网推荐  e.Item.Cells[3].Text = Convert.ToString(totalFreight);
源代码网推荐  
源代码网推荐  } }
源代码网推荐  
源代码网推荐  </script>
源代码网推荐  
源代码网推荐  <form id="frmDataGridTotals" method="post" runat="server">
源代码网推荐  
源代码网推荐  <asp:DataGrid id="dgNorthwind"
源代码网推荐  
源代码网推荐  style="Z-INDEX: 101; LEFT: 24px; POSITION: absolute; TOP: 32px"
源代码网推荐  
源代码网推荐  runat="server" Height="320px" Width="496px"
源代码网推荐  
源代码网推荐  AutoGenerateColumns="False"
源代码网推荐  
源代码网推荐  onfiltered="doTotal"
源代码网推荐  
源代码网推荐  ShowFooter="True" CellPadding="4" CellSpacing="0"
源代码网推荐  
源代码网推荐  BorderStyle="Solid" BorderWidth="1" Gridlines="None"
源代码网推荐  
源代码网推荐  BorderColor="Black"
源代码网推荐  
源代码网推荐  ItemStyle-Font-Name="Verdana"
源代码网推荐  
源代码网推荐  ItemStyle-Font-Size="9pt"
源代码网推荐  
源代码网推荐  HeaderStyle-Font-Name="Verdana"
源代码网推荐  
源代码网推荐  HeaderStyle-Font-Size="10pt"
源代码网推荐  
源代码网推荐  HeaderStyle-Font-Bold="True"
源代码网推荐  
源代码网推荐  HeaderStyle-ForeColor="White"
源代码网推荐  
源代码网推荐  HeaderStyle-BackColor="Gray"
源代码网推荐  
源代码网推荐  FooterStyle-Font-Name="Verdana"
源代码网推荐  
源代码网推荐  FooterStyle-Font-Size="10pt"
源代码网推荐  
源代码网推荐  FooterStyle-Font-Bold="True"
源代码网推荐  
源代码网推荐  FooterStyle-ForeColor="Red"
源代码网推荐  
源代码网推荐  FooterStyle-BackColor="Gray">
源代码网推荐  
源代码网推荐  <Columns>
源代码网推荐  
源代码网推荐  <asp:BoundColumn DataField="OrderID" HeaderText="#" ItemStyle-Width="10%"
源代码网推荐  
源代码网推荐   HeaderStyle-HorizontalAlign="Center" />
源代码网推荐  
源代码网推荐  <asp:BoundColumn DataField="ShipName" HeaderText="Customer" ItemStyle
源代码网推荐  
源代码网推荐  -Width="50%" />
源代码网推荐  
源代码网推荐  <asp:BoundColumn DataField="ShipCountry" HeaderText="Country" ItemStyle
源代码网推荐  
源代码网推荐  -Width="20%" />
源代码网推荐  
源代码网推荐  <asp:BoundColumn DataField="Freight" HeaderText="Freight" ItemStyle-Width="20%"
源代码网推荐  
源代码网推荐   />
源代码网推荐  
源代码网推荐  </Columns></asp:DataGrid>
源代码网推荐  
源代码网推荐  </form></body></HTML>
源代码网推荐  
源代码网推荐  或许首先你注意到的是此页面没有使用code-behind特性。所有的代码都放在aspx文件中。页面首部必需的import指令保证了数据交互所需代码的可用性。页面事件Page_Load调用了BindData方法,这正是与数据库交互的地方。它连接到数据库并创建SqlDataReader对象,此对象包含了由SQL语句返回的记录。对象SqlDataReader通过对象DataGrid的DataSource属性把DataGrid对象放入页面中。对象DataGrid的DataBind方法负责装入数据。DataGrid的HTML定义了栏目及其格式,包括颜色、字体、对齐等。
源代码网推荐  
源代码网推荐  DataBind方法还保持着对来自数据源的数据栏的动态求和。以下代码返回一行数据的详细个数:
源代码网推荐  
源代码网推荐  double currentFreight = Convert.ToDouble(DataBinder._Eval(e.Item.DataItem,
源代码网推荐  
源代码网推荐   "Freight"));
源代码网推荐  
源代码网推荐  此行代码返回由_Eval语句获得的值,并将其转换为保持动态求和所必需的格式。一旦返回了此值,它将被加到total变量中。在DataGrid中的每行都将进行此操作。以下代码定义了一行:
源代码网推荐  
源代码网推荐  if(e.Item.ItemType==ListItemType.Item |
源代码网推荐  
源代码网推荐  e.Item.ItemType==ListItemType.AlternatingItem)
源代码网推荐  
源代码网推荐  此语句对于DataGrid中的每行都返回true。语句的其他部分决定了何时显示总计数量。当所有的行(if语句的第一部分为false)都被处理时该语句被执行,除非以以下语句开头:
源代码网推荐  
源代码网推荐  else if (e.Item.ItemType == ListItemType.Footer)
源代码网推荐  
源代码网推荐  当到达页脚时,此语句将返回true。既然我们对页眉没有兴趣,我们必须确定这是否是页脚。在这种情况下,总计值将显示在DataGrid合适的栏中。必须记住栏的编号是从0开始。由此,我们得出栏2和栏3,而不是栏3和栏4。你可以通过用Item的索引值来覆盖Cells属性中的Text属性来完成此工作。
源代码网推荐  
源代码网推荐  e.Item.Cells[2].Text = "Total:";
源代码网推荐  
源代码网推荐  e.Item.Cells[3].Text = Convert.ToString(totalFreight);
源代码网推荐  
源代码网推荐  需要注意总计值在显示前被转换为字符串值。
源代码网推荐  
源代码网推荐  另一种方法
源代码网推荐  当并不急需获得数据的总计值时,你可以使用另外一种方法。此方法通过SQL SUM命令来计算栏中数值的总数。这种方法的缺点在于它需要一个单独的数据库调用,并且结果必须存放在DataSet或其他类似的对象中。
源代码网推荐  
源代码网推荐  翻页
源代码网推荐  你或许想知道DataGrid 翻页是如何影响到总计值的。本文中的范例代码将显示对屏幕所示的数据的求和,所以对每页来说结果都会不同(你必须调整代码以保持对每个变量的求和,但这已经超出了本文所讨论的范围)。
源代码网推荐  
源代码网推荐  由于你不能使用SqlDataReader来翻页,本文的代码将不能用于翻页的情况。但你可以将代码修改为使用DataSet对象以利用其提供的翻页选项。以下代码改变将完成此工作:
源代码网推荐  
源代码网推荐  SqlCommand comm = new SqlCommand(sSQL, conn);
源代码网推荐  
源代码网推荐  SqlDataAdapter da = new SqlDataAdapter();
源代码网推荐  
源代码网推荐  da.SelectCommand = comm;
源代码网推荐  
源代码网推荐  DataSet ds = new DataSet();
源代码网推荐  
源代码网推荐  da.Fill(ds);
源代码网推荐  
源代码网推荐  dgNorthwind.DataSource = ds;

源代码网推荐
源代码网推荐
源代码网推荐
源代码网供稿.
网友评论 (0)
会员中心
网络编程
本站推荐
网络编程之精华