2013-12-17 10:40:31 +01:00
|
|
|
|
|
|
|
Some tests for parsing full queries.
|
|
|
|
|
2013-12-17 12:21:36 +01:00
|
|
|
> {-# LANGUAGE OverloadedStrings #-}
|
2013-12-17 10:40:31 +01:00
|
|
|
> module Language.SQL.SimpleSQL.FullQueries (fullQueriesTests) where
|
|
|
|
|
|
|
|
> import Language.SQL.SimpleSQL.TestTypes
|
|
|
|
> import Language.SQL.SimpleSQL.Syntax
|
|
|
|
|
|
|
|
|
|
|
|
> fullQueriesTests :: TestItem
|
|
|
|
> fullQueriesTests = Group "queries" $ map (uncurry TestQueryExpr)
|
|
|
|
> [("select count(*) from t"
|
|
|
|
> ,makeSelect
|
|
|
|
> {qeSelectList = [(Nothing, App "count" [Star])]
|
|
|
|
> ,qeFrom = [TRSimple "t"]
|
|
|
|
> }
|
|
|
|
> )
|
|
|
|
|
|
|
|
> ,("select a, sum(c+d) as s\n\
|
|
|
|
> \ from t,u\n\
|
|
|
|
> \ where a > 5\n\
|
|
|
|
> \ group by a\n\
|
|
|
|
> \ having count(1) > 5\n\
|
|
|
|
> \ order by s"
|
|
|
|
> ,makeSelect
|
|
|
|
> {qeSelectList = [(Nothing, Iden "a")
|
|
|
|
> ,(Just "s"
|
|
|
|
> ,App "sum" [BinOp (Iden "c")
|
|
|
|
> "+" (Iden "d")])]
|
|
|
|
> ,qeFrom = [TRSimple "t", TRSimple "u"]
|
|
|
|
> ,qeWhere = Just $ BinOp (Iden "a") ">" (NumLit "5")
|
|
|
|
> ,qeGroupBy = [Iden "a"]
|
|
|
|
> ,qeHaving = Just $ BinOp (App "count" [NumLit "1"])
|
|
|
|
> ">" (NumLit "5")
|
2013-12-17 17:28:31 +01:00
|
|
|
> ,qeOrderBy = [OrderField (Iden "s") Asc NullsOrderDefault]
|
2013-12-17 10:40:31 +01:00
|
|
|
> }
|
|
|
|
> )
|
|
|
|
> ]
|