我有很多記錄的gridview,所以不得不使用ObjectDataSource,以便只提取將顯示在頁面上的記錄,即如果總共100條記錄,並且頁面大小爲10,在每個頁面上單擊只從數據庫中提取10條記錄。 請在下面找到gridview + objectdatasource selectmethod調用兩次
/// ASPX
<asp:GridView ID="grdModulesList" CssClass="moduleList" runat="server"
AutoGenerateColumns="False" HeaderStyle-Font-Size="Smaller"
Font-Size="Small" AllowPaging="true" AllowSorting="True" OnRowCreated="grdModulesList_RowCreated"
OnRowDataBound="grdModulesList_RowDataBound" BackColor="White" BorderColor="Blue"
BorderStyle="None" BorderWidth="1px" CellPadding="3" PageSize="20">
<Columns>
<asp:BoundField DataField="collection_id" Visible="False" />
<asp:BoundField HeaderText="Item" />
<asp:BoundField HeaderText="Module Name" DataField="module_name" SortExpression="module_name"
ControlStyle-CssClass="moduleName" />
<asp:BoundField HeaderText="File Name" DataField="module_file_name" SortExpression="module_file_name" />
<asp:BoundField HeaderText="ID" DataField="defect_number" SortExpression="defect_number" />
<asp:BoundField HeaderText="Actions" />
</Columns>
<RowStyle BorderColor="Blue" BorderStyle="Solid" CssClass="grid_width" BorderWidth="2px"
Height="20px" />
<PagerStyle BackColor="#FFFF99" ForeColor="Red" HorizontalAlign="Center" Height="20px" />
<FooterStyle ForeColor="black" Font-Bold="true" />
<SelectedRowStyle Font-Size="Smaller" />
<HeaderStyle Font-Size="Smaller" BorderStyle="Solid" BackColor="Gold" Font-Bold="True"
ForeColor="Black" Height="30px" />
<AlternatingRowStyle BorderColor="#3366FF" BorderStyle="Solid" BorderWidth="1px" />
</asp:GridView>
//.aspx.cs
ObjectDataSource ods = new ObjectDataSource();
ods.ID = "ods";
ods.SelectMethod = "GRAD_ModuleListforCollection_Subset"; //method to fetch records from DB
ods.EnablePaging = true;
ods.TypeName = "pmAdmin.classes.data.ApplicationData";
ods.StartRowIndexParameterName = "StartRecord";
ods.MaximumRowsParameterName = "PageSize";
ods.SortParameterName = "SortBy";
ods.SelectCountMethod = "GRAD_Total_Modules";
Parameter p1 = new Parameter("userID", TypeCode.String, userId);
ods.SelectParameters.Add(p1);
panelModuleList.Controls.Add(ods); //add objectDatasource control to a panel
grdModulesList.DataSourceID = ods.ID;
grdModulesList.DataBind();
代碼//方法GRAD_ModuleListforCollection_Subset
public System.Data.DataSet GRAD_ModuleListforCollection_Subset(string userID, int StartRecord, int PageSize, string SortBy)
{}
記錄正確綁定到Gridview,但問題是用於從DB獲取記錄的方法,即GRAD_ModuleListforCollection_Subset在頁面上每次單擊時調用兩次。 例如:如果I 2頁上的單擊方法稱爲 ()第一次與startRecord = 0,頁大小= 20 ()稱爲第二次用startRecord = 20,頁大小= 20
點擊頁面上後2如果我點擊頁面3 ()第一次與startRecord = 20,頁大小= 20 ()稱爲第二次用startRecord = 40,頁大小= 20
的每一頁點擊,第一負載由具有先前的值。
請幫我解決這個問題。
在此先感謝。