一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - ASP.NET教程 - Datalist控件使用存儲(chǔ)過程來分頁實(shí)現(xiàn)代碼

Datalist控件使用存儲(chǔ)過程來分頁實(shí)現(xiàn)代碼

2019-10-12 11:11asp.net教程網(wǎng) ASP.NET教程

.net使用過程中,數(shù)據(jù)多的時(shí)候需要分頁,本文將介紹如何使用存儲(chǔ)過程來分頁,需要的朋友可以了解下

--------------前臺(tái):------------------- 

復(fù)制代碼代碼如下:


<body> 
<form id="form1" runat="server"> 
<div> 
<asp:DataList ID="DataList1" runat="server" 
onitemcommand="DataList1_ItemCommand" 
oncancelcommand="DataList1_CancelCommand" 
ondeletecommand="DataList1_DeleteCommand" oneditcommand="DataList1_EditCommand" 
onupdatecommand="DataList1_UpdateCommand" 
onitemdatabound="DataList1_ItemDataBound"> 
<EditItemTemplate> 
<table style="width: 100%; height: 180px;"> 
<tr> 
<td class="style4"> 
商品名:</td> 
<td class="style2"> 
<asp:TextBox ID="txtProductName" runat="server" 
Text='<%# Eval("ProductName") %>'></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td class="style4"> 
規(guī)格:</td> 
<td class="style2"> 
<asp:TextBox ID="txtProductStandard" runat="server" 
Text='<%# Eval("ProductStandard") %>'></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td class="style4"> 
包裝率:</td> 
<td class="style2"> 
<asp:TextBox ID="txtPackagingRatio" runat="server" 
Text='<%# Eval("PackagingRatio") %>'></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td class="style4"> 
商品條碼:</td> 
<td class="style2"> 
<asp:TextBox ID="txtArticleNum" runat="server" Text='<%# Eval("ArticleNum") %>'></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td class="style4"> 
價(jià)格:</td> 
<td class="style2"> 
<asp:TextBox ID="txtPrice" runat="server" Text='<%# Eval("Price") %>'></asp:TextBox> 
</td> 
</tr> 
<tr> 
<td class="style4"> 
<asp:Button ID="btnUpdate" runat="server" CommandArgument='<%# Eval("PId") %>' 
CommandName="update" Height="21px" Text="更新" /> 
</td> 
<td class="style2"> 
<asp:Button ID="btnCancel" runat="server" CommandName="cancel" Text="取消" /> 
</td> 
</tr> 
</table> 
</EditItemTemplate> 
<ItemTemplate> 
產(chǎn)品名:<asp:Label ID="Label1" runat="server" Text='<%# Eval("ProductName") %>'></asp:Label> 
<br /> 
規(guī)格:<asp:Label ID="Label2" runat="server" Text='<%# Eval("ProductStandard") %>'></asp:Label> 
<br /> 
包裝率:<asp:Label ID="Label3" runat="server" Text='<%# Eval("PackagingRatio") %>'></asp:Label> 
<br /> 
商品條碼:<asp:Label ID="Label4" runat="server" Text='<%# Eval("ArticleNum") %>'></asp:Label> 
<br /> 
超市價(jià)格:<asp:Label ID="Label5" runat="server" Text='<%# Eval("Price") %>'></asp:Label> 
<br /> 
<asp:Button ID="btnEdit" runat="server" Text="編輯" CommandName="Edit" /> 
 <asp:Button ID="btnDelete" runat="server" Text="刪除" 
CommandArgument='<%# Eval("PId") %>' CommandName="delete" /> 
<br /> 
<br /> 
<asp:Button ID="Button1" runat="server" CommandArgument='<%# Eval("PId") %>' 
CommandName="Buy" Text="放入購物車" /> 
<br /> 
</ItemTemplate> 
</asp:DataList> 
<br /> 
<br /> 
<asp:Button ID="btnFirst" runat="server" onclick="btnFirst_Click" 
Text="|<" /> 
 <asp:Button ID="btnPrev" runat="server" onclick="btnPrev_Click" Text="<" 
style="height: 21px" /> 
 <asp:Button ID="btnNext" runat="server" onclick="btnNext_Click" Text=">" /> 
 <asp:Button ID="btnLast" runat="server" onclick="btnLast_Click" Text=">|" /> 
 <asp:Label ID="Label1" runat="server"></asp:Label> 
<asp:TextBox ID="txtPageNumber" runat="server" Height="26px" Width="43px"></asp:TextBox> 
<asp:CompareValidator ID="CompareValidator1" runat="server" 
ControlToValidate="txtPageNumber" Display="Dynamic" ErrorMessage="必須為整數(shù)!" 
ForeColor="#FF3300" Operator="DataTypeCheck" Type="Integer"></asp:CompareValidator> 
<asp:RangeValidator ID="RangeValidator1" runat="server" 
ControlToValidate="txtPageNumber" Display="Dynamic" ErrorMessage="輸入數(shù)據(jù)不合法!" 
ForeColor="Red" MaximumValue="9" MinimumValue="1"></asp:RangeValidator> 
<asp:Button ID="btnGo" runat="server" onclick="btnGo_Click" Text="Go" /> 
<br /> 
<asp:HiddenField ID="HiddenField1" runat="server" /> 
<asp:HiddenField ID="HiddenField2" runat="server" /> 
</div> 
</form> 
</body> 


---------------------后臺(tái):--------------------------- 

復(fù)制代碼代碼如下:


protected void Page_Load(object sender, EventArgs e) 

if (!IsPostBack) 

bindProduct(1); 


private void bindProduct(int pageIndex) 

string constr = ConfigurationManager.ConnectionStrings["studentConnectionString"].ConnectionString; 
using (SqlConnection con = new SqlConnection(constr)) 

con.Open(); 
using (SqlCommand cmd = con.CreateCommand()) 

cmd.CommandType = CommandType.StoredProcedure; 
cmd.CommandText = "sp_Product_Select_by_Page_rowNumber"; 
cmd.Parameters.AddWithValue("@pageSize", 3); 
cmd.Parameters.Add("@pageCount", System.Data.DbType.Int32).Direction = ParameterDirection.Output; 
cmd.Parameters.AddWithValue("@pageIndex", pageIndex); 
SqlDataAdapter adapter = new SqlDataAdapter(cmd); 
DataTable dt = new DataTable(); 
adapter.Fill(dt); 
this.DataList1.DataSource = dt; 
this.DataList1.DataBind(); 
int pageCount = Convert.ToInt32(cmd.Parameters["@pageCount"].Value); 
this.HiddenField1.Value = pageCount.ToString(); 
this.HiddenField2.Value = pageIndex.ToString(); 



protected void DataList1_ItemCommand(object source, DataListCommandEventArgs e) 

if (e.CommandName == "Buy") 

Response.Write(e.CommandArgument.ToString()); 


protected void DataList1_EditCommand(object source, DataListCommandEventArgs e) 

this.DataList1.EditItemIndex = e.Item.ItemIndex; 
this.bindProduct(1); 

protected void DataList1_UpdateCommand(object source, DataListCommandEventArgs e) 

string ProName = (e.Item.FindControl("txtProductName") as TextBox).Text; 
string ProStandarde = (e.Item.FindControl("txtProductStandard") as TextBox).Text; 
string ProPackaging = (e.Item.FindControl("txtPackagingRatio") as TextBox).Text; 
string ProArtialeNum = (e.Item.FindControl("txtArticleNum") as TextBox).Text; 
string ProPrice = (e.Item.FindControl("txtPrice") as TextBox).Text; 
string sql = "update Product set ProductName=@ProductName,ProductStandard=@ProductStandard,PackagingRatio=@PackagingRatio,ArticleNum=@ArticleNum,Price=@Price where PId=@pid"; 
SqlParameter[] pms = new SqlParameter[]{ 
new SqlParameter("@ProductName",ProName), 
new SqlParameter("@ProductStandard",ProStandarde), 
new SqlParameter("@PackagingRatio",ProPackaging), 
new SqlParameter("@ArticleNum",ProArtialeNum), 
new SqlParameter("@Price",ProPrice), 
new SqlParameter("@pid",e.CommandArgument) 
}; 
SQLHelper.ExecuteNonQuery(sql, pms); 

protected void DataList1_CancelCommand(object source, DataListCommandEventArgs e) 

this.DataList1.EditItemIndex = -1; 
this.bindProduct(1); 

protected void DataList1_DeleteCommand(object source, DataListCommandEventArgs e) 

string sql = "delete from Product where PId=@pid"; 
SqlParameter pms = new SqlParameter("@pid", e.CommandArgument); 
SQLHelper.ExecuteNonQuery(sql, pms); 
this.bindProduct(1); 

protected void btnFirst_Click(object sender, EventArgs e) 

this.bindProduct(1); 

protected void btnPrev_Click(object sender, EventArgs e) 

int index = Convert.ToInt32(this.HiddenField2.Value); 
if (index > 1) 

index--; 
this.bindProduct(index); 


protected void btnNext_Click(object sender, EventArgs e) 

int index = Convert.ToInt32(this.HiddenField2.Value); 
int pageCount = Convert.ToInt32(this.HiddenField1.Value); 
if (index<pageCount) 

index++; 
this.bindProduct(index); 


protected void btnLast_Click(object sender, EventArgs e) 

this.bindProduct(Convert.ToInt32(this.HiddenField1.Value)); 

protected void btnGo_Click(object sender, EventArgs e) 

if (Convert.ToInt32(txtPageNumber.Text) <= Convert.ToInt32(HiddenField1.Value)) 

this.bindProduct(Convert.ToInt32(txtPageNumber.Text)); 

else 

Response.Write("您輸入的頁數(shù)超出了總頁數(shù),如有需要請重新輸入!"); 


protected void DataList1_ItemDataBound(object sender, DataListItemEventArgs e) 

Label1.Text = "第" + (HiddenField2.Value).ToString() + "頁,共" + HiddenField1.Value.ToString() + "頁"; 


---------------------存儲(chǔ)過程----------------------- 

復(fù)制代碼代碼如下:


CREATE PROCEDURE [dbo].[sp_Product_Select_by_Page_rowNumber] 
@pageSize int, --每頁記錄數(shù)量 
@pageCount int output, --總頁數(shù) 
@pageIndex int --當(dāng)前頁索引號 
AS 
BEGIN 
declare @totalRecords int 
select @totalRecords = count(PId) from Product 
if(@totalRecords % @pageSize = 0) 
set @pageCount = @totalRecords / @pageSize; 
else 
set @pageCount = @totalRecords / @pageSize +1; 
with temp as (select row_number() over (order by PId) as id,* from Product) 
select * from temp where id between (@pageIndex -1)*@pageSize +1 and @pageIndex * @pageSize 
return @totalRecords 
end 
GO 


----------------Web.config:------------------- 

復(fù)制代碼代碼如下:


<connectionStrings> 
<add name="studentConnectionString" connectionString="Data Source=PC_THINK-THINK;Initial Catalog=student;Persist Security Info=True;User ID=sa;Password=111111" 
providerName="System.Data.SqlClient" /> 
</connectionStrings> 


----------------------SQLHelper類:------------------------------------- 

復(fù)制代碼代碼如下:


public static String connStr = ConfigurationManager.ConnectionStrings["studentConnectionString"].ConnectionString; 
public static int ExecuteNonQuery(string sql, params SqlParameter[] pms) 

using (SqlConnection con = new SqlConnection(connStr)) 

using (SqlCommand cmd = new SqlCommand(sql, con)) 

if (pms != null) 

cmd.Parameters.AddRange(pms); 

con.Open(); 
return cmd.ExecuteNonQuery(); 



public static DataTable ExecuteDataTable(string sql, params SqlParameter[] pms) 

DataTable dt = new DataTable(); 
SqlDataAdapter adapter = new SqlDataAdapter(sql,connStr); 
if (pms != null) 

adapter.SelectCommand.Parameters.AddRange(pms); 

adapter.Fill(dt); 
return dt; 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产专区一va亚洲v天堂 | 2019年国产高清情侣视频 | 操老逼视频 | 希望影院高清免费观看视频 | 干b视频在线观看 | 免费理伦片在线观看全网站 | 国产午夜精品一区二区三区不卡 | 日韩香蕉视频 | 亚洲图片 自拍偷拍 | 禁止的爱善良的未删减版hd | 精品手机在线1卡二卡3卡四卡 | 日本黄色大片网站 | bt岛www| 逼逼爱 | 无遮免费网站在线入口 | 免费观看国产精品 | 国产高清视频一区二区 | www.四虎com| 大象传媒短视频网站 | 3d动漫美女被吸乳羞羞视频 | 赤色疑惑 | 好奇害死猫在线观看 | 男人机机桶女人 | 国产麻豆传媒在线观看 | 四虎免费影院在线播放 | 国产视频久久久久 | 很黄的孕妇a级黄毛片 | 国产成人亚洲精品一区二区在线看 | 99久久精品免费看国产高清 | 91九色porny国产美女一区 | 欧美成人禁片在线观看俄罗斯 | 99欧美精品| 操老妇| 亚洲 欧美 偷自乱 图片 | 国产一线天 | 99在线免费视频 | 美女扒开腿让男人桶爽动态图片 | 办公室恋情在线观看 | 免费在线视频成人 | 国产无限制自拍 | 嫩草成人影院 |