2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
Section 14 in Foundation
|
|
|
|
|
|
|
|
|
|
|
|
> module Language.SQL.SimpleSQL.SQL2011DataManipulation (sql2011DataManipulationTests) where
|
|
|
|
|
|
|
|
> import Language.SQL.SimpleSQL.TestTypes
|
2015-08-01 19:26:00 +02:00
|
|
|
> import Language.SQL.SimpleSQL.Syntax
|
2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
> sql2011DataManipulationTests :: TestItem
|
2015-08-01 19:26:00 +02:00
|
|
|
> sql2011DataManipulationTests = Group "sql 2011 data manipulation tests"
|
|
|
|
> [
|
2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
|
|
|
|
14 Data manipulation
|
|
|
|
|
|
|
|
|
|
|
|
14.1 <declare cursor>
|
|
|
|
|
|
|
|
<declare cursor> ::=
|
|
|
|
DECLARE <cursor name> <cursor properties>
|
|
|
|
FOR <cursor specification>
|
|
|
|
|
|
|
|
14.2 <cursor properties>
|
|
|
|
|
|
|
|
<cursor properties> ::=
|
|
|
|
[ <cursor sensitivity> ] [ <cursor scrollability> ] CURSOR
|
|
|
|
[ <cursor holdability> ]
|
|
|
|
[ <cursor returnability> ]
|
|
|
|
|
|
|
|
<cursor sensitivity> ::=
|
|
|
|
SENSITIVE
|
|
|
|
| INSENSITIVE
|
|
|
|
| ASENSITIVE
|
|
|
|
|
|
|
|
<cursor scrollability> ::=
|
|
|
|
SCROLL
|
|
|
|
| NO SCROLL
|
|
|
|
|
|
|
|
<cursor holdability> ::=
|
|
|
|
WITH HOLD
|
|
|
|
| WITHOUT HOLD
|
|
|
|
|
|
|
|
<cursor returnability> ::=
|
|
|
|
WITH RETURN
|
|
|
|
| WITHOUT RETURN
|
|
|
|
|
|
|
|
14.3 <cursor specification>
|
|
|
|
|
|
|
|
<cursor specification> ::=
|
|
|
|
<query expression> [ <updatability clause> ]
|
|
|
|
|
|
|
|
<updatability clause> ::=
|
|
|
|
FOR { READ ONLY | UPDATE [ OF <column name list> ] }
|
|
|
|
|
|
|
|
14.4 <open statement>
|
|
|
|
|
|
|
|
<open statement> ::=
|
|
|
|
OPEN <cursor name>
|
|
|
|
|
|
|
|
14.5 <fetch statement>
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
<fetch statement> ::=
|
2015-08-01 17:08:54 +02:00
|
|
|
FETCH [ [ <fetch orientation> ] FROM ] <cursor name> INTO <fetch target list>
|
|
|
|
|
|
|
|
<fetch orientation> ::=
|
|
|
|
NEXT
|
|
|
|
| PRIOR
|
|
|
|
| FIRST
|
|
|
|
| LAST
|
|
|
|
| { ABSOLUTE | RELATIVE } <simple value specification>
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
<fetch target list> ::=
|
2015-08-01 17:08:54 +02:00
|
|
|
<target specification> [ { <comma> <target specification> }... ]
|
|
|
|
|
|
|
|
|
|
|
|
14.6 <close statement>
|
|
|
|
|
|
|
|
<close statement> ::=
|
|
|
|
CLOSE <cursor name>
|
|
|
|
|
|
|
|
14.7 <select statement: single row>
|
|
|
|
|
|
|
|
<select statement: single row> ::=
|
|
|
|
SELECT [ <set quantifier> ] <select list>
|
|
|
|
INTO <select target list>
|
|
|
|
<table expression>
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
<select target list> ::=
|
2015-08-01 17:08:54 +02:00
|
|
|
<target specification> [ { <comma> <target specification> }... ]
|
|
|
|
|
|
|
|
14.8 <delete statement: positioned>
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
<delete statement: positioned> ::=
|
2015-08-01 17:08:54 +02:00
|
|
|
DELETE FROM <target table> [ [ AS ] <correlation name> ]
|
|
|
|
WHERE CURRENT OF <cursor name>
|
|
|
|
|
|
|
|
<target table> ::=
|
|
|
|
<table name>
|
|
|
|
| ONLY <left paren> <table name> <right paren>
|
|
|
|
|
|
|
|
14.9 <delete statement: searched>
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
<delete statement: searched> ::=
|
2015-08-01 17:08:54 +02:00
|
|
|
DELETE FROM <target table>
|
|
|
|
[ FOR PORTION OF <application time period name>
|
|
|
|
FROM <point in time 1> TO <point in time 2> ]
|
|
|
|
[ [ AS ] <correlation name> ]
|
|
|
|
[ WHERE <search condition> ]
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> (TestStatement SQL2011 "delete from t"
|
|
|
|
> $ Delete [Name "t"] Nothing Nothing)
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "delete from t as u"
|
|
|
|
> $ Delete [Name "t"] (Just (Name "u")) Nothing)
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "delete from t where x = 5"
|
|
|
|
> $ Delete [Name "t"] Nothing
|
|
|
|
> (Just $ BinOp (Iden [Name "x"]) [Name "="] (NumLit "5")))
|
2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "delete from t as u where u.x = 5"
|
|
|
|
> $ Delete [Name "t"] (Just (Name "u"))
|
|
|
|
> (Just $ BinOp (Iden [Name "u", Name "x"]) [Name "="] (NumLit "5")))
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
14.10 <truncate table statement>
|
2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
<truncate table statement> ::=
|
|
|
|
TRUNCATE TABLE <target table> [ <identity column restart option> ]
|
|
|
|
|
|
|
|
<identity column restart option> ::=
|
|
|
|
CONTINUE IDENTITY
|
|
|
|
| RESTART IDENTITY
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "truncate table t"
|
|
|
|
> $ Truncate [Name "t"] DefaultIdentityRestart)
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "truncate table t continue identity"
|
|
|
|
> $ Truncate [Name "t"] ContinueIdentity)
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "truncate table t restart identity"
|
|
|
|
> $ Truncate [Name "t"] RestartIdentity)
|
2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
14.11 <insert statement>
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
<insert statement> ::=
|
2015-08-01 17:08:54 +02:00
|
|
|
INSERT INTO <insertion target> <insert columns and source>
|
|
|
|
|
|
|
|
<insertion target> ::=
|
|
|
|
<table name>
|
|
|
|
|
|
|
|
<insert columns and source> ::=
|
|
|
|
<from subquery>
|
|
|
|
| <from constructor>
|
|
|
|
| <from default>
|
|
|
|
|
|
|
|
<from subquery> ::=
|
|
|
|
[ <left paren> <insert column list> <right paren> ]
|
|
|
|
[ <override clause> ]
|
|
|
|
<query expression>
|
|
|
|
|
|
|
|
<from constructor> ::=
|
|
|
|
[ <left paren> <insert column list> <right paren> ]
|
|
|
|
[ <override clause> ]
|
|
|
|
<contextually typed table value constructor>
|
|
|
|
|
|
|
|
<override clause> ::=
|
|
|
|
OVERRIDING USER VALUE
|
|
|
|
| OVERRIDING SYSTEM VALUE
|
|
|
|
|
|
|
|
<from default> ::=
|
|
|
|
DEFAULT VALUES
|
|
|
|
|
|
|
|
<insert column list> ::=
|
|
|
|
<column name list>
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "insert into t select * from u"
|
|
|
|
> $ Insert [Name "t"] Nothing
|
|
|
|
> $ InsertQuery makeSelect
|
|
|
|
> {qeSelectList = [(Star, Nothing)]
|
|
|
|
> ,qeFrom = [TRSimple [Name "u"]]})
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "insert into t(a,b,c) select * from u"
|
|
|
|
> $ Insert [Name "t"] (Just [Name "a", Name "b", Name "c"])
|
|
|
|
> $ InsertQuery makeSelect
|
|
|
|
> {qeSelectList = [(Star, Nothing)]
|
|
|
|
> ,qeFrom = [TRSimple [Name "u"]]})
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "insert into t default values"
|
|
|
|
> $ Insert [Name "t"] Nothing DefaultInsertValues)
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "insert into t values(1,2)"
|
|
|
|
> $ Insert [Name "t"] Nothing
|
|
|
|
> $ InsertQuery $ Values [[NumLit "1", NumLit "2"]])
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "insert into t values (1,2),(3,4)"
|
|
|
|
> $ Insert [Name "t"] Nothing
|
|
|
|
> $ InsertQuery $ Values [[NumLit "1", NumLit "2"]
|
|
|
|
> ,[NumLit "3", NumLit "4"]])
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011
|
|
|
|
> "insert into t values (default,null,array[],multiset[])"
|
|
|
|
> $ Insert [Name "t"] Nothing
|
|
|
|
> $ InsertQuery $ Values [[Iden [Name "default"]
|
|
|
|
> ,Iden [Name "null"]
|
|
|
|
> ,Array (Iden [Name "array"]) []
|
|
|
|
> ,MultisetCtor []]])
|
2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
14.12 <merge statement>
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
<merge statement> ::=
|
2015-08-01 17:08:54 +02:00
|
|
|
MERGE INTO <target table> [ [ AS ] <merge correlation name> ]
|
|
|
|
USING <table reference>
|
|
|
|
ON <search condition> <merge operation specification>
|
|
|
|
|
|
|
|
<merge correlation name> ::=
|
|
|
|
<correlation name>
|
|
|
|
|
|
|
|
<merge operation specification> ::=
|
|
|
|
<merge when clause>...
|
|
|
|
|
|
|
|
<merge when clause> ::=
|
|
|
|
<merge when matched clause>
|
|
|
|
| <merge when not matched clause>
|
|
|
|
|
|
|
|
<merge when matched clause> ::=
|
|
|
|
WHEN MATCHED [ AND <search condition> ]
|
|
|
|
THEN <merge update or delete specification>
|
|
|
|
|
|
|
|
<merge update or delete specification> ::=
|
|
|
|
<merge update specification>
|
|
|
|
| <merge delete specification>
|
|
|
|
|
|
|
|
<merge when not matched clause> ::=
|
|
|
|
WHEN NOT MATCHED [ AND <search condition> ]
|
|
|
|
THEN <merge insert specification>
|
|
|
|
|
|
|
|
<merge update specification> ::=
|
|
|
|
UPDATE SET <set clause list>
|
|
|
|
|
|
|
|
<merge delete specification> ::=
|
|
|
|
DELETE
|
|
|
|
|
|
|
|
<merge insert specification> ::=
|
|
|
|
INSERT [ <left paren> <insert column list> <right paren> ]
|
|
|
|
[ <override clause> ]
|
|
|
|
VALUES <merge insert value list>
|
|
|
|
|
|
|
|
<merge insert value list> ::=
|
|
|
|
<left paren>
|
|
|
|
<merge insert value element> [ { <comma> <merge insert value element> }... ]
|
|
|
|
<right paren>
|
|
|
|
|
|
|
|
<merge insert value element> ::=
|
|
|
|
<value expression>
|
|
|
|
| <contextually typed value specification>
|
|
|
|
|
|
|
|
14.13 <update statement: positioned>
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
<updatestatement: positioned> ::=
|
2015-08-01 17:08:54 +02:00
|
|
|
UPDATE <target table> [ [ AS ] <correlation name> ]
|
|
|
|
SET <set clause list>
|
|
|
|
WHERE CURRENT OF <cursor name>
|
|
|
|
|
|
|
|
14.14 <update statement: searched>
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
<update statement: searched> ::=
|
2015-08-01 17:08:54 +02:00
|
|
|
UPDATE <target table>
|
|
|
|
[ FOR PORTION OF <application time period name>
|
|
|
|
FROM <point in time 1> TO <point in time 2> ]
|
|
|
|
[ [ AS ] <correlation name> ]
|
|
|
|
SET <set clause list>
|
|
|
|
[ WHERE <search condition> ]
|
|
|
|
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "update t set a=b"
|
|
|
|
> $ Update [Name "t"] Nothing
|
|
|
|
> [Set [Name "a"] (Iden [Name "b"])] Nothing)
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "update t set a=b, c=5"
|
|
|
|
> $ Update [Name "t"] Nothing
|
|
|
|
> [Set [Name "a"] (Iden [Name "b"])
|
|
|
|
> ,Set [Name "c"] (NumLit "5")] Nothing)
|
2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "update t set a=b where a>5"
|
|
|
|
> $ Update [Name "t"] Nothing
|
|
|
|
> [Set [Name "a"] (Iden [Name "b"])]
|
|
|
|
> $ Just $ BinOp (Iden [Name "a"]) [Name ">"] (NumLit "5"))
|
2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "update t as u set a=b where u.a>5"
|
|
|
|
> $ Update [Name "t"] (Just $ Name "u")
|
|
|
|
> [Set [Name "a"] (Iden [Name "b"])]
|
|
|
|
> $ Just $ BinOp (Iden [Name "u",Name "a"])
|
|
|
|
> [Name ">"] (NumLit "5"))
|
2015-08-01 17:08:54 +02:00
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ,(TestStatement SQL2011 "update t set (a,b)=(3,5)"
|
|
|
|
> $ Update [Name "t"] Nothing
|
|
|
|
> [SetMultiple [[Name "a"],[Name "b"]]
|
|
|
|
> [NumLit "3", NumLit "5"]] Nothing)
|
2015-08-01 17:08:54 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
14.15 <set clause list>
|
|
|
|
|
|
|
|
<set clause list> ::=
|
|
|
|
<set clause> [ { <comma> <set clause> }... ]
|
|
|
|
|
|
|
|
<set clause> ::=
|
|
|
|
<multiple column assignment>
|
|
|
|
| <set target> <equals operator> <update source>
|
|
|
|
|
|
|
|
<set target> ::=
|
|
|
|
<update target>
|
|
|
|
| <mutated set clause>
|
|
|
|
|
|
|
|
<multiple column assignment> ::=
|
|
|
|
<set target list> <equals operator> <assigned row>
|
|
|
|
|
|
|
|
<set target list> ::=
|
|
|
|
<left paren> <set target> [ { <comma> <set target> }... ] <right paren>
|
|
|
|
|
|
|
|
<assigned row> ::=
|
|
|
|
<contextually typed row value expression>
|
|
|
|
|
|
|
|
<update target> ::=
|
|
|
|
<object column>
|
|
|
|
| <object column>
|
|
|
|
<left bracket or trigraph> <simple value specification> <right bracket or trigraph>
|
|
|
|
|
|
|
|
<object column> ::=
|
|
|
|
<column name>
|
|
|
|
|
|
|
|
<mutated set clause> ::=
|
|
|
|
<mutated target> <period> <method name>
|
|
|
|
|
|
|
|
<mutated target> ::=
|
|
|
|
<object column>
|
|
|
|
| <mutated set clause>
|
|
|
|
|
|
|
|
<update source> ::=
|
|
|
|
<value expression>
|
|
|
|
| <contextually typed value specification>
|
|
|
|
|
|
|
|
14.16 <temporary table declaration>
|
|
|
|
|
|
|
|
<temporary table declaration> ::=
|
|
|
|
DECLARE LOCAL TEMPORARY TABLE <table name> <table element list>
|
|
|
|
[ ON COMMIT <table commit action> ROWS ]
|
|
|
|
|
|
|
|
14.17 <free locator statement>
|
|
|
|
|
|
|
|
<free locator statement> ::=
|
|
|
|
FREE LOCATOR <locator reference> [ { <comma> <locator reference> }... ]
|
|
|
|
|
|
|
|
<locator reference> ::=
|
|
|
|
<host parameter name>
|
|
|
|
| <embedded variable name>
|
|
|
|
| <dynamic parameter specification>
|
|
|
|
|
|
|
|
14.18 <hold locator statement>
|
|
|
|
|
|
|
|
<hold locator statement> ::=
|
|
|
|
HOLD LOCATOR <locator reference> [ { <comma> <locator reference> }... ]
|
|
|
|
|
|
|
|
|
2015-08-01 19:26:00 +02:00
|
|
|
> ]
|