add support for odbc scalar exprs
This commit is contained in:
parent
d8b351472f
commit
c8d745fd28
|
@ -1104,6 +1104,25 @@ separate suffix.
|
||||||
> i <- names
|
> i <- names
|
||||||
> pure $ \v -> Collate v i
|
> pure $ \v -> Collate v i
|
||||||
|
|
||||||
|
== odbc syntax
|
||||||
|
|
||||||
|
the parser supports three kinds of odbc syntax, two of which are
|
||||||
|
scalar expressions (the other is a variation on joins)
|
||||||
|
|
||||||
|
|
||||||
|
> odbcExpr :: Parser ValueExpr
|
||||||
|
> odbcExpr = between (symbol "{") (symbol "}")
|
||||||
|
> (odbcTimeLit <|> odbcFunc)
|
||||||
|
> where
|
||||||
|
> odbcTimeLit =
|
||||||
|
> OdbcLiteral <$> choice [OLDate <$ keyword "d"
|
||||||
|
> ,OLTime <$ keyword "t"
|
||||||
|
> ,OLTimestamp <$ keyword "ts"]
|
||||||
|
> <*> singleQuotesOnlyStringTok
|
||||||
|
> -- todo: this parser is too general, the expr part
|
||||||
|
> -- should be only a function call (from a whitelist of functions)
|
||||||
|
> -- or the extract operator
|
||||||
|
> odbcFunc = OdbcFunc <$> (keyword "fn" *> valueExpr)
|
||||||
|
|
||||||
== operators
|
== operators
|
||||||
|
|
||||||
|
@ -1254,7 +1273,8 @@ documenting/fixing.
|
||||||
> ,subquery
|
> ,subquery
|
||||||
> ,intervalLit
|
> ,intervalLit
|
||||||
> ,specialOpKs
|
> ,specialOpKs
|
||||||
> ,idenExpr]
|
> ,idenExpr
|
||||||
|
> ,odbcExpr]
|
||||||
> <?> "value expression"
|
> <?> "value expression"
|
||||||
|
|
||||||
expose the b expression for window frame clause range between
|
expose the b expression for window frame clause range between
|
||||||
|
|
|
@ -227,6 +227,16 @@ which have been changed to try to improve the layout of the output.
|
||||||
> valueExpr d (VEComment cmt v) =
|
> valueExpr d (VEComment cmt v) =
|
||||||
> vcat $ map comment cmt ++ [valueExpr d v]
|
> vcat $ map comment cmt ++ [valueExpr d v]
|
||||||
|
|
||||||
|
> valueExpr _ (OdbcLiteral t s) =
|
||||||
|
> text "{" <> lt t <+> quotes (text s) <> text "}"
|
||||||
|
> where
|
||||||
|
> lt OLDate = text "d"
|
||||||
|
> lt OLTime = text "t"
|
||||||
|
> lt OLTimestamp = text "ts"
|
||||||
|
|
||||||
|
> valueExpr d (OdbcFunc e) =
|
||||||
|
> text "{fn" <+> valueExpr d e <> text "}"
|
||||||
|
|
||||||
> unname :: Name -> String
|
> unname :: Name -> String
|
||||||
> unname (Name Nothing n) = n
|
> unname (Name Nothing n) = n
|
||||||
> unname (Name (Just (s,e)) n) =
|
> unname (Name (Just (s,e)) n) =
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
> ,Frame(..)
|
> ,Frame(..)
|
||||||
> ,FrameRows(..)
|
> ,FrameRows(..)
|
||||||
> ,FramePos(..)
|
> ,FramePos(..)
|
||||||
|
> ,OdbcLiteralType(..)
|
||||||
> -- * Query expressions
|
> -- * Query expressions
|
||||||
> ,QueryExpr(..)
|
> ,QueryExpr(..)
|
||||||
> ,makeSelect
|
> ,makeSelect
|
||||||
|
@ -215,6 +216,10 @@ in other places
|
||||||
> | MultisetQueryCtor QueryExpr
|
> | MultisetQueryCtor QueryExpr
|
||||||
> | NextValueFor [Name]
|
> | NextValueFor [Name]
|
||||||
> | VEComment [Comment] ValueExpr
|
> | VEComment [Comment] ValueExpr
|
||||||
|
> | OdbcLiteral OdbcLiteralType String
|
||||||
|
> -- ^ an odbc literal e.g. {d '2000-01-01'}
|
||||||
|
> | OdbcFunc ValueExpr
|
||||||
|
> -- ^ an odbc function call e.g. {fn CHARACTER_LENGTH('test')}
|
||||||
> deriving (Eq,Show,Read,Data,Typeable)
|
> deriving (Eq,Show,Read,Data,Typeable)
|
||||||
|
|
||||||
> -- | Represents an identifier name, which can be quoted or unquoted.
|
> -- | Represents an identifier name, which can be quoted or unquoted.
|
||||||
|
@ -304,6 +309,15 @@ not sure if scalar subquery, exists and unique should be represented like this
|
||||||
> | UnboundedFollowing
|
> | UnboundedFollowing
|
||||||
> deriving (Eq,Show,Read,Data,Typeable)
|
> deriving (Eq,Show,Read,Data,Typeable)
|
||||||
|
|
||||||
|
|
||||||
|
> -- | the type of an odbc literal (e.g. {d '2000-01-01'}),
|
||||||
|
> -- correpsonding to the letter after the opening {
|
||||||
|
> data OdbcLiteralType = OLDate
|
||||||
|
> | OLTime
|
||||||
|
> | OLTimestamp
|
||||||
|
> deriving (Eq,Show,Read,Data,Typeable)
|
||||||
|
|
||||||
|
|
||||||
> -- | Represents a query expression, which can be:
|
> -- | Represents a query expression, which can be:
|
||||||
> --
|
> --
|
||||||
> -- * a regular select;
|
> -- * a regular select;
|
||||||
|
|
52
tools/Language/SQL/SimpleSQL/Odbc.lhs
Normal file
52
tools/Language/SQL/SimpleSQL/Odbc.lhs
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
|
||||||
|
> module Language.SQL.SimpleSQL.Odbc (odbcTests) where
|
||||||
|
|
||||||
|
> import Language.SQL.SimpleSQL.TestTypes
|
||||||
|
> import Language.SQL.SimpleSQL.Syntax
|
||||||
|
|
||||||
|
> odbcTests :: TestItem
|
||||||
|
> odbcTests = Group "odbc" [
|
||||||
|
> Group "datetime" [
|
||||||
|
> e "{d '2000-01-01'}" (OdbcLiteral OLDate "2000-01-01")
|
||||||
|
> ,e "{t '12:00:01.1'}" (OdbcLiteral OLTime "12:00:01.1")
|
||||||
|
> ,e "{ts '2000-01-01 12:00:01.1'}"
|
||||||
|
> (OdbcLiteral OLTimestamp "2000-01-01 12:00:01.1")
|
||||||
|
> ]
|
||||||
|
> ,Group "functions" [
|
||||||
|
> e "{fn CHARACTER_LENGTH(string_exp)}"
|
||||||
|
> $ OdbcFunc (ap "CHARACTER_LENGTH" [iden "string_exp"])
|
||||||
|
> ,e "{fn EXTRACT(day from t)}"
|
||||||
|
> $ OdbcFunc (SpecialOpK [Name Nothing "extract"] (Just $ Iden [Name Nothing "day"]) [("from", Iden [Name Nothing "t"])])
|
||||||
|
> ,e "{fn now()}"
|
||||||
|
> $ OdbcFunc (ap "now" [])
|
||||||
|
> ,e "{fn CONVERT('2000-01-01', SQL_DATE)}"
|
||||||
|
> $ OdbcFunc (ap "CONVERT"
|
||||||
|
> [StringLit "'" "'" "2000-01-01"
|
||||||
|
> ,iden "SQL_DATE"])
|
||||||
|
> ,e "{fn CONVERT({fn CURDATE()}, SQL_DATE)}"
|
||||||
|
> $ OdbcFunc (ap "CONVERT"
|
||||||
|
> [OdbcFunc (ap "CURDATE" [])
|
||||||
|
> ,iden "SQL_DATE"])
|
||||||
|
> ]
|
||||||
|
> {-,Group "outer join" [
|
||||||
|
> ParseQueryExpr defaultParseFlags
|
||||||
|
> "select * from {oj t1 left outer join t2 on true}"
|
||||||
|
> $ makeSelect
|
||||||
|
> {selSelectList = sl [si $ Star ea]
|
||||||
|
> ,selTref = [OdbcTableRef ea (JoinTref ea (tref "t1") Unnatural LeftOuter Nothing
|
||||||
|
> (tref "t2") (Just $ JoinOn ea (BooleanLit ea True)))]}]
|
||||||
|
> ,Group "check parsing bugs" [
|
||||||
|
> ParseQueryExpr defaultParseFlags
|
||||||
|
> "select {fn CONVERT(cint,SQL_BIGINT)} from t;"
|
||||||
|
> $ makeSelect
|
||||||
|
> {selSelectList = sl [si $ OdbcFunc ea (App ea (name "CONVERT")
|
||||||
|
> [ei "cint"
|
||||||
|
> ,ei "SQL_BIGINT"])]
|
||||||
|
> ,selTref = [tref "t"]}]-}
|
||||||
|
> ]
|
||||||
|
> where
|
||||||
|
> e = TestValueExpr ansi2011 {allowOdbc = True}
|
||||||
|
> --tsql = ParseProcSql defaultParseFlags {pfDialect=sqlServerDialect}
|
||||||
|
> ap n = App [Name Nothing n]
|
||||||
|
> iden n = Iden [Name Nothing n]
|
||||||
|
|
|
@ -26,6 +26,7 @@ test data to the Test.Framework tests.
|
||||||
> import Language.SQL.SimpleSQL.QueryExprs
|
> import Language.SQL.SimpleSQL.QueryExprs
|
||||||
> import Language.SQL.SimpleSQL.TableRefs
|
> import Language.SQL.SimpleSQL.TableRefs
|
||||||
> import Language.SQL.SimpleSQL.ValueExprs
|
> import Language.SQL.SimpleSQL.ValueExprs
|
||||||
|
> import Language.SQL.SimpleSQL.Odbc
|
||||||
> import Language.SQL.SimpleSQL.Tpch
|
> import Language.SQL.SimpleSQL.Tpch
|
||||||
> import Language.SQL.SimpleSQL.LexerTests
|
> import Language.SQL.SimpleSQL.LexerTests
|
||||||
|
|
||||||
|
@ -45,6 +46,7 @@ order on the generated documentation.
|
||||||
> Group "parserTest"
|
> Group "parserTest"
|
||||||
> [lexerTests
|
> [lexerTests
|
||||||
> ,valueExprTests
|
> ,valueExprTests
|
||||||
|
> ,odbcTests
|
||||||
> ,queryExprComponentTests
|
> ,queryExprComponentTests
|
||||||
> ,queryExprsTests
|
> ,queryExprsTests
|
||||||
> ,tableRefTests
|
> ,tableRefTests
|
||||||
|
|
Loading…
Reference in a new issue