主頁 > 知識庫 > Datalist控件使用存儲過程來分頁實(shí)現(xiàn)代碼

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

熱門標(biāo)簽:蘇州銷售外呼系統(tǒng)預(yù)算 保山電話外呼管理系統(tǒng)怎么用 太原外呼電銷機(jī)器人費(fèi)用 電話機(jī)器人廣告話術(shù) 外呼系統(tǒng)用員工身份證 使用智能電話機(jī)器人違法嗎 東莞語音電銷機(jī)器人排名 淘寶地圖標(biāo)注如何做 朝陽市地圖標(biāo)注
--------------前臺:-------------------
復(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">
價格:/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 />
超市價格:asp:Label ID="Label5" runat="server" Text='%# Eval("Price") %>'>/asp:Label>
br />
asp:Button ID="btnEdit" runat="server" Text="編輯" CommandName="Edit" />
nbsp;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="|lt;" />
nbsp;asp:Button ID="btnPrev" runat="server" onclick="btnPrev_Click" Text="lt;"
style="height: 21px" />
nbsp;asp:Button ID="btnNext" runat="server" onclick="btnNext_Click" Text="gt;" />
nbsp;asp:Button ID="btnLast" runat="server" onclick="btnLast_Click" Text="gt;|" />
nbsp;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>

---------------------后臺:---------------------------
復(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 (indexpageCount)
{
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() + "頁";
}

---------------------存儲過程-----------------------
復(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;
}
您可能感興趣的文章:
  • 獲取DataList控件的主鍵和索引實(shí)用圖解
  • 通過RadioButton對DataList控件進(jìn)行單選實(shí)例說明
  • 動態(tài)加載用戶控件至DataList并為用戶控件賦值實(shí)例演示
  • asp.net datalist 用法
  • DataList中TextBox onfocus調(diào)用后臺void靜態(tài)方法及獲取相應(yīng)行數(shù)

標(biāo)簽:綏化 西藏 潛江 洛陽 呼倫貝爾 運(yùn)城 克拉瑪依 阿里

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Datalist控件使用存儲過程來分頁實(shí)現(xiàn)代碼》,本文關(guān)鍵詞  Datalist,控件,使用,存儲,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Datalist控件使用存儲過程來分頁實(shí)現(xiàn)代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于Datalist控件使用存儲過程來分頁實(shí)現(xiàn)代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章