国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

ASP.NET怎么操作DataTable實例應用

來源:懂視網 責編:小采 時間:2020-11-27 22:42:08
文檔

ASP.NET怎么操作DataTable實例應用

ASP.NET怎么操作DataTable實例應用:有機會在博客園的博問頻道上看到一個問題,《ASP.NET怎么操作DataTable》: 如上圖,左邊的這個表是程序構建出來的,不是數據庫表,怎么通過操作DataTable手段得到右邊的四個表? Insus.NET嘗試做了一下,算是練習DataTable的功力了。效果如下: 根據
推薦度:
導讀ASP.NET怎么操作DataTable實例應用:有機會在博客園的博問頻道上看到一個問題,《ASP.NET怎么操作DataTable》: 如上圖,左邊的這個表是程序構建出來的,不是數據庫表,怎么通過操作DataTable手段得到右邊的四個表? Insus.NET嘗試做了一下,算是練習DataTable的功力了。效果如下: 根據

有機會在博客園的博問頻道上看到一個問題,《ASP.NET怎么操作DataTable》:

如上圖,左邊的這個表是程序構建出來的,不是數據庫表,怎么通過操作DataTable手段得到右邊的四個表?

Insus.NET嘗試做了一下,算是練習DataTable的功力了。效果如下:

根據最初數據,Insus.NET在.aspx內放置了一個Gridview,用來顯示最開始的數據。

代碼如下:
View Code


<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="false">
<Columns>
<asp:TemplateField>
<HeaderTemplate>
Name
</HeaderTemplate>
<ItemTemplate>
<%# Eval("Name") %>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
Quantity
</HeaderTemplate>
<ItemTemplate>
<%# Eval("Quantity") %>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>

創建一個DataTable,并填充數據:
代碼如下:
View Code

DataTable GetData()
{
DataTable table = new DataTable();
table.Columns.Add("Name", typeof(string));
table.Columns.Add("Quantity", typeof(int));
table.Rows.Add("a", 1);
table.Rows.Add("a", 2);
table.Rows.Add("b", 2);
table.Rows.Add("b", 2);
table.Rows.Add("c", 1);
table.Rows.Add("c", 2);
table.Rows.Add("c", 3);
table.Rows.Add("c", 4);
return table;
}

然后為剛才創建的Gridview綁定這個DataTable:
代碼如下:
View Code

protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
Data_Binding();
}
}

private void Data_Binding()
{
this.GridView1.DataSource = GetData();
this.GridView1.DataBind();
}

為了得到報表1,它有三個字段,名稱(Name),數量(Amount)和行數(Rowcount),Insus.NET還參考源數據,它還有一個數量(Quantity)字段。因此,Insus.NET寫了一個類別Item,為以下導出報表作準備:
代碼如下:
Item

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

/// <summary>
/// Summary description for Item
/// </summary>
namespace Insus.NET
{
public class Item
{
private string _Name;
private int _Quantity;
private int _Amount;
private int _RowCount;

public string Name
{
get { return _Name; }
set { _Name = value; }
}
public int Quantity
{
get { return _Quantity; }
set { _Quantity = value; }
}
public int Amount
{
get { return _Amount; }
set { _Amount = value; }
}
public int RowCount
{
get { return _RowCount; }
set { _RowCount = value; }
}

public Item()
{
//
// TODO: Add constructor logic here
//
}

public Item(string name, int quantity)
{
this._Name = name;
this._Quantity = quantity;
}

public Item(string name, int amount,int rowCount)
{
this._Name = name;
this._Amount = amount;
this._RowCount = rowCount;
}
}
}

OK,現在我們寫一個報表,在.aspx放在一個按鈕,以及一個GridView,來顯示報表,注意一個字段的綁定。
代碼如下:
View Code

<asp:Button ID="ButtonReport1" runat="server" Text="報表1" OnClick="ButtonReport1_Click" />
<asp:GridView ID="GridView2" runat="server" AutoGenerateColumns="false">
<Columns>
<asp:TemplateField>
<HeaderTemplate>
Name
</HeaderTemplate>
<ItemTemplate>
<%# Eval("Name") %>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
Amount
</HeaderTemplate>
<ItemTemplate>
<%# Eval("Amount") %>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField>
<HeaderTemplate>
RowCount
</HeaderTemplate>
<ItemTemplate>
<%# Eval("RowCount") %>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>

在.cs 寫click事件:
代碼如下:
View Code


protected void ButtonReport1_Click(object sender, EventArgs e)
{
SortedList<string, Item> _sl = new SortedList<string, Item>();

DataTable otable = GetData();
foreach (DataRow dr in otable.Rows)
{
if (_sl.ContainsKey(dr["Name"].ToString()))
{
_sl[dr["Name"].ToString()].Amount += Convert.ToInt32(dr["Quantity"]);
_sl[dr["Name"].ToString()].RowCount += 1;
}
else
{
Item i = new Item(dr["Name"].ToString(), Convert.ToInt32(dr["Quantity"]), 1);
_sl.Add(dr["Name"].ToString(), i);
}
}

this.GridView2.DataSource = _sl.Values;
this.GridView2.DataBind();
}

第一份報表,大功告成,只要DataTable數源數據有變化,報表也會隨之變化。

接下來,完成第二個報表,在Insus.NET使用Repeater包含Repeater來實現。因此,前臺Html代碼如下,其中第一個Repeate內放置了一個HiddenField,來存儲名稱(Name)字段,當作子Repeater的參考傳入。
代碼如下:
View Code


<asp:Button ID="ButtonReport2" runat="server" Text="報表2" OnClick="ButtonReport2_Click" />
<asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="Repeater1_ItemDataBound">
<ItemTemplate>
<asp:HiddenField ID="HiddenField1" runat="server" Value='<%# Container.DataItem %>' />
<asp:Repeater ID="Repeater2" runat="server">
<HeaderTemplate>
<table border="1" cellspacing="0" cellpadding="5" style="margin: 10px; border-collapse: collapse;">
<tr>
<td>Name</td>
<td>Quantity</td>
</tr>
</HeaderTemplate>
<ItemTemplate>
<tr>
<td><%# Eval("Name") %></td>
<td><%# Eval("Quantity") %></td>
</tr>
</ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
</asp:Repeater>
</ItemTemplate>
</asp:Repeater>

首先,我們需要從DataTable,獲取名稱(Name)唯一的記錄存儲起來,作為第一個Repeate控件的數據集數據源。
代碼如下:
View Code


protected void ButtonReport2_Click(object sender, EventArgs e)
{
this.Repeater1.DataSource = Names();
this.Repeater1.DataBind();
}

List<string> Names()
{
List<string> t = new List<string>();
DataTable otable = GetData();
foreach (DataRow dr in otable.Rows)
{
if (!t.Contains(dr["Name"].ToString()))
t.Add(dr["Name"].ToString());
}
return t;
}

我們還要寫第二個Repeater控件的數據源:
代碼如下:
View Code


List<Item> GetDataByName(string name)
{
List<Item> o = new List<Item>();
DataTable otable = GetData();
foreach (DataRow dr in otable.Rows)
{
if (name == dr["Name"].ToString())
{
Item i = new Item(dr["Name"].ToString(), Convert.ToInt32(dr["Quantity"]));
o.Add(i);
}
}
return o;
}

為第二個Repeater控件綁定數據源,在綁寫之前,得先找到這個控件,因此,你需要在第一個Repeater控件寫OnItemDataBound="Repeater1_ItemDataBound"事件:
代碼如下:
View Code


protected void Repeater1_ItemDataBound(object sender, RepeaterItemEventArgs e)
{
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
{
if (e.Item.FindControl("HiddenField1") != null && e.Item.FindControl("Repeater2") != null)
{
var hiddenField = e.Item.FindControl("HiddenField1") as HiddenField;
var repeater = e.Item.FindControl("Repeater2") as Repeater;
repeater.DataSource = GetDataByName(hiddenField.Value);
repeater.DataBind();
}
}
}

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

ASP.NET怎么操作DataTable實例應用

ASP.NET怎么操作DataTable實例應用:有機會在博客園的博問頻道上看到一個問題,《ASP.NET怎么操作DataTable》: 如上圖,左邊的這個表是程序構建出來的,不是數據庫表,怎么通過操作DataTable手段得到右邊的四個表? Insus.NET嘗試做了一下,算是練習DataTable的功力了。效果如下: 根據
推薦度:
標簽: 操作 如何 應用
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 精品视频一区二区三区四区五区 | 91久久国产情侣真实对白 | 久久久久久国产a免费观看黄色大片 | 精品久久久一二三区 | 国内精品一区二区三区 | 2021国产成人精品久久 | 久久国产精品最新一区 | 国产99久久精品一区二区 | 国产成人精品久久二区二区 | 亚洲 欧美 日韩 另类 | 欧美日韩高清 | 成人精品久久 | 日韩亚洲第一页 | 欧美一区二区三区视视频 | 亚洲成色999久久网站 | 久久亚洲欧美综合激情一区 | 国内精品伊人久久大香线焦 | 亚洲一区中文字幕 | 手机在线观看国产精选免费 | 欧美一区三区 | 日本三级韩国三级韩级在线观看 | 欧美视频亚洲色图 | 欧美性猛交一区二区三区精品 | 国产第8页| 国产一区欧美二区 | 福利一区三区 | 亚洲高清色 | 91精品国产亚一区二区三区 | 精品国产一区二区三区在线 | 国产一区亚洲二区 | 国产欧美在线视频 | 日韩电影免费看 | 中文字幕一区二区三区在线观看 | 国产69精品久久久久777 | 亚洲精品二三区伊人久久 | 日韩精品一区二区三区毛片 | 日韩不卡一区二区三区 | 亚洲色图第一页 | 欧美国产日韩在线播放 | 91亚洲欧美综合高清在线 | 亚洲综合日韩在线亚洲欧美专区 |