1
Fork 0
simple-sql-parser/tools/Language/SQL/SimpleSQL/Odbc.lhs

53 lines
2.3 KiB
Plaintext
Raw Normal View History

2016-02-21 22:43:19 +01:00
> 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"])
> ]
2016-02-21 22:48:55 +01:00
> ,Group "outer join" [
> TestQueryExpr ansi2011 {allowOdbc=True}
> "select * from {oj t1 left outer join t2 on expr}"
2016-02-21 22:43:19 +01:00
> $ makeSelect
2016-02-21 22:48:55 +01:00
> {qeSelectList = [(Star,Nothing)]
> ,qeFrom = [TROdbc $ TRJoin (TRSimple [Name Nothing "t1"]) False JLeft (TRSimple [Name Nothing "t2"])
> (Just $ JoinOn $ Iden [Name Nothing "expr"])]}]
2016-02-21 22:43:19 +01:00
> ,Group "check parsing bugs" [
2016-02-21 22:48:55 +01:00
> TestQueryExpr ansi2011 {allowOdbc=True}
2016-02-21 22:43:19 +01:00
> "select {fn CONVERT(cint,SQL_BIGINT)} from t;"
> $ makeSelect
2016-02-21 22:48:55 +01:00
> {qeSelectList = [(OdbcFunc (ap "CONVERT"
> [iden "cint"
> ,iden "SQL_BIGINT"]), Nothing)]
> ,qeFrom = [TRSimple [Name Nothing "t"]]}]
2016-02-21 22:43:19 +01:00
> ]
> where
> e = TestValueExpr ansi2011 {allowOdbc = True}
> --tsql = ParseProcSql defaultParseFlags {pfDialect=sqlServerDialect}
> ap n = App [Name Nothing n]
> iden n = Iden [Name Nothing n]