Skip to main content
Version: v3.0

Sorting

This guide demonstrates use cases for the Order Sieve. This sieve is used when an order parameter is found in the query parameters, e.g. ?order=created_at.

General usage

The canonical use case for the order sieve is to sort results by a certain column. For example, if it is needed to sort users by their birthday, the request and its query parameters could be:

/users?order=birthday

Ascending vs. Descending

By default, the ascending order will be used, i.e. order=age means the younger ones (lower age) would the first results.

In order to use the descending order, a leading dash must be used in front of the column name. So

/users?order=-age

would use the descending order and return older people (greater age) as the first results.

Multiple clauses

Multiple order clauses are supported. It is possible, for instance, to order users by name and, if two people have the same the name, order by age then. For that, column names should be separated by commas.

/users?order=name,-age

Related models columns can also be used for ordering. For instance, if a user has many blogs and blogs have many blog posts, it would be possible to order blog posts using the blog attribute published_at:

/blog_posts?order=blog.published_at

It is also possible to go deeper in the relationships:

/blog_posts?order=blog.user.name

To combine them:

/blog_posts?order=blog.user.name,blog.published_at

And to use the desecending modifier:

/blog_posts?order=-blog.user.name,-blog.published_at

In this case, BlogPost could have a direct has_one :user, through: :blog relationship with User. Naturally, directly accessing User columns without passing through Blog would work, but is highly discouraged and should be avoided at all costs, so the most explicit relationship path should always be used.

BAD

/blog_posts?order=user.name

Good

/blog_posts?order=blog.user.name