Skip to content

Latest commit

 

History

History
46 lines (31 loc) · 2.83 KB

Sorting_d2ce3f5.md

File metadata and controls

46 lines (31 loc) · 2.83 KB
loio
d2ce3f51e5e34198b0c1a7f6ddd98def

Sorting

The OData V4 model supports server side sorting on lists.

To use server side sorting, set the operation mode to sap.ui.model.odata.OperationMode.Server as described unter Filtering.

ODataListBinding allows to set static and dynamic sorters:

  • For setting a static sorter, the $orderby system query option in the binding parameters is used. The static sorter value is sent with every data service request for the binding. The static sorter cannot be overwritten for an existing binding.

  • The dynamic sorter is a sap.ui.model.odata.Sorter instance, or an array thereof in which case the sorters are concatenated. You can set the initial value for the dynamic sorter in ODataModel.bindList, or declaratively in an XML view with the sorter property in an aggregation's binding information. For setting the dynamic sorter, the ODataListBinding.sort method is used. The sorter that is given here overwrites the initial value specified on binding construction.

Dynamic sorters are transformed to an OData $orderby system query option value and the static sorters are always appended as secondary sort criterion. In this example, the equipments are first ordered by Category (dynamic sorter) and then by Name (secondary sort criterion, static sorter). For a description of the group property, see getGroup.

Example: Dynamic and static sorters

#js
<Table growing="true" growingThreshold="5" id="Equipments"
    items="{
            path : '/Equipments',
            parameters : {
                $$operationMode : 'Server',
                $orderby : 'Name',                             <-- static sorter
                $select : 'Category,EmployeeId,ID,Name'
            },
            sorter : {                                      <-- dynamic sorter; can be overwritten by calling sort on the list binding
                path : 'Category',
                group : true                                <-- optional, see parameter vGroup of sap.ui.model.Sorter
            }
        }">

In this example, the equipments are first ordered by Category (dynamic sorter) and then by Name (secondary sort criterion, static sorter).