无法使用对象数据源进行排序

时间:2014-09-09 09:12:10

标签: c# objectdatasource

我正在使用objectdatasource来填充我的网格 当我选择网格所在的页面时,它会进入方法select和selectcount,但是在排序时会给我找不到列。 奇怪的是我在方法选择上有一个断点,如果我尝试按fiedl排序,参数sSortColumn应该有列id,它应该输入断点但是它没有。

这是我的网格和objectdatasource

 <ig:WebDataGrid ID="WebDataGridAutAssiduidade" runat="server" AutoGenerateColumns="False" Width="100%"
    Height="99%"  DataKeyFields="ID" DataSourceID="odsAutAssiduidade" >
     <EmptyRowsTemplate>
        Sem registos...</EmptyRowsTemplate>        
    <Columns>     
        <ig:TemplateDataField Key="chkBox" Width="40px">
            <HeaderTemplate>
                <asp:CheckBox runat="server" ID="chkAll" CssClass="center" OnClick="SelectAll(this)" />
            </HeaderTemplate>
            <ItemTemplate>
                <asp:CheckBox runat="server" ID="chk" CssClass="center" />
            </ItemTemplate>
        </ig:TemplateDataField>
        <ig:BoundDataField DataFieldName="ID" Hidden="false" Key="ID">
            <Header Text="ID" />
        </ig:BoundDataField>  
        </Columns>   
    <behaviors>
     <ig:Sorting>
        </ig:Sorting>
        <ig:EditingCore>
        </ig:EditingCore>
        <ig:ColumnResizing>
        </ig:ColumnResizing>

        <ig:Paging PagerMode="NumericFirstLast" PageSize="20" QuickPages="5">
        </ig:Paging>
        <ig:RowSelectors RowNumbering="True">
        </ig:RowSelectors>
    </behaviors>
    </ig:WebDataGrid>
    <asp:ObjectDataSource ID="odsAutAssiduidade" runat="server" EnablePaging="True" SelectCountMethod="GetAsAutAssiduidadeCount"
    SelectMethod="GetAsAutAssiduidade" TypeName="IdOntime.AsAutorizacoesAssiduidade" SortParameterName="sSortType"
    EnableCaching="True" EnableViewState="True" OldValuesParameterFormatString="original_{0}" StartRowIndexParameterName="startRowIndex" MaximumRowsParameterName="maxRows">
    <selectparameters>
   <asp:Parameter Name="sSortType" Type="String" />
</selectparameters>
</asp:ObjectDataSource>

这是方法

 public DataTable GetAsAutAssiduidade(String sSortType, int maxRows, int startRowIndex)
    {
        return new DataTable();//testing -
    }

    public int GetAsAutAssiduidadeCount(String sSortType)
    {
        return NRows;

    }

我做错了什么? 我正在使用一个名为webdatagrid的infragistics组件,我允许通过添加行为进行排序。

感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

对于常规<asp:GridView />,它确实适用于我。至于为什么断点没有被击中 - 你在对象数据源中启用缓存。禁用它以便断点将触发:

<asp:ObjectDataSource ...
   EnableCaching="false" ... />

请注意,默认情况下,网格未排序,因此sSortType可以是:"""ID""ID DESC"