2013-12-13 11:39:26 +01:00
|
|
|
|
|
|
|
> module Syntax (QueryExpr(..)
|
2013-12-13 13:08:33 +01:00
|
|
|
> ,makeSelect
|
2013-12-13 11:39:26 +01:00
|
|
|
> ,ScalarExpr(..)
|
|
|
|
> ,TableRef(..)
|
|
|
|
> ,JoinType(..)
|
|
|
|
> ,JoinCondition(..))
|
|
|
|
> where
|
|
|
|
|
|
|
|
|
|
|
|
> data ScalarExpr = Literal String
|
|
|
|
> | Identifier String
|
|
|
|
> | Identifier2 String String
|
|
|
|
> | Star
|
|
|
|
> | Star2 String
|
|
|
|
> | App String [ScalarExpr]
|
|
|
|
> | Op String [ScalarExpr]
|
|
|
|
> | Case (Maybe ScalarExpr) -- test value
|
|
|
|
> [(ScalarExpr,ScalarExpr)] -- when branches
|
|
|
|
> (Maybe ScalarExpr) -- else value
|
|
|
|
> | Parens ScalarExpr
|
|
|
|
> deriving (Eq,Show)
|
|
|
|
|
|
|
|
> data QueryExpr
|
|
|
|
> = Select
|
|
|
|
> {qeSelectList :: [(Maybe String,ScalarExpr)]
|
|
|
|
> ,qeFrom :: [TableRef]
|
|
|
|
> ,qeWhere :: Maybe ScalarExpr
|
|
|
|
> ,qeGroupBy :: [ScalarExpr]
|
|
|
|
> ,qeHaving :: Maybe ScalarExpr
|
|
|
|
> ,qeOrderBy :: [ScalarExpr]
|
|
|
|
> } deriving (Eq,Show)
|
|
|
|
|
|
|
|
> makeSelect :: QueryExpr
|
|
|
|
> makeSelect = Select {qeSelectList = []
|
|
|
|
> ,qeFrom = []
|
|
|
|
> ,qeWhere = Nothing
|
|
|
|
> ,qeGroupBy = []
|
|
|
|
> ,qeHaving = Nothing
|
|
|
|
> ,qeOrderBy = []}
|
|
|
|
|
|
|
|
|
|
|
|
> data TableRef = SimpleTableRef String
|
|
|
|
> | JoinTableRef JoinType TableRef TableRef (Maybe JoinCondition)
|
|
|
|
> | JoinParens TableRef
|
|
|
|
> | JoinAlias TableRef String
|
|
|
|
> | JoinQueryExpr QueryExpr
|
|
|
|
> deriving (Eq,Show)
|
|
|
|
|
|
|
|
> data JoinType = Inner | JLeft | JRight | Full | Cross
|
|
|
|
> deriving (Eq,Show)
|
|
|
|
|
|
|
|
> data JoinCondition = JoinOn ScalarExpr
|
|
|
|
> | JoinUsing [String]
|
|
|
|
> | JoinNatural
|
|
|
|
> deriving (Eq,Show)
|