Copyright | 2013 Kei Hibino |
---|---|
License | BSD3 |
Maintainer | [email protected] |
Stability | experimental |
Portability | unknown |
Safe Haskell | None |
Language | Haskell2010 |
Database.Relational.Query.Monad.Trans.Ordering
Description
This module defines monad transformer which lift from query into query with ordering.
- data Orderings c m a
- orderings :: Monad m => m a -> Orderings c m a
- type OrderingTerms = [OrderingTerm]
- orderBy :: (Monad m, ProjectableOrdering (Projection c)) => Projection c t -> Order -> Orderings c m ()
- asc :: (Monad m, ProjectableOrdering (Projection c)) => Projection c t -> Orderings c m ()
- desc :: (Monad m, ProjectableOrdering (Projection c)) => Projection c t -> Orderings c m ()
- extractOrderingTerms :: (Monad m, Functor m) => Orderings c m a -> m (a, OrderingTerms)
Transformer into query with ordering
Type to accumulate ordering context.
Type c
is ordering term projection context type.
Instances
MonadPartition c m => MonadPartition c (Orderings c m) Source # |
|
MonadQualify q m => MonadQualify q (Orderings c m) Source # |
|
MonadRestrict rc m => MonadRestrict rc (Orderings c m) Source # |
|
MonadTrans (Orderings c) Source # | |
Monad m => Monad (Orderings c m) Source # | |
Functor m => Functor (Orderings c m) Source # | |
Applicative m => Applicative (Orderings c m) Source # | |
MonadAggregate m => MonadAggregate (Orderings c m) Source # |
|
MonadQuery m => MonadQuery (Orderings c m) Source # |
|
type OrderingTerms = [OrderingTerm] Source #
Type for order-by terms
API of query with ordering
Arguments
:: (Monad m, ProjectableOrdering (Projection c)) | |
=> Projection c t | Ordering terms to add |
-> Order | Order direction |
-> Orderings c m () | Result context with ordering |
Add ordering terms.
Arguments
:: (Monad m, ProjectableOrdering (Projection c)) | |
=> Projection c t | Ordering terms to add |
-> Orderings c m () | Result context with ordering |
Add ascendant ordering term.
Arguments
:: (Monad m, ProjectableOrdering (Projection c)) | |
=> Projection c t | Ordering terms to add |
-> Orderings c m () | Result context with ordering |
Add descendant ordering term.
Result
extractOrderingTerms :: (Monad m, Functor m) => Orderings c m a -> m (a, OrderingTerms) Source #
Run Orderings
to get OrderingTerms