Commit f71a1f73 authored by Alexander Barkov's avatar Alexander Barkov

MDEV-10411 Providing compatibility for basic PL/SQL constructs

Part 4: AS/IS keyword before a function or a procedure body
parent 892af780
SET sql_mode=ORACLE; SET sql_mode=ORACLE;
# Testing labels # Testing labels
CREATE FUNCTION f1 (a INT) RETURNS CLOB CREATE FUNCTION f1 (a INT) RETURNS CLOB AS
BEGIN BEGIN
<<label1>> <<label1>>
BEGIN BEGIN
...@@ -19,7 +19,7 @@ SELECT f1(2); ...@@ -19,7 +19,7 @@ SELECT f1(2);
f1(2) f1(2)
IS NOT 1 IS NOT 1
DROP FUNCTION f1; DROP FUNCTION f1;
CREATE FUNCTION f1 (a INT) RETURNS INT CREATE FUNCTION f1 (a INT) RETURNS INT IS
BEGIN BEGIN
<<label1>> <<label1>>
LOOP LOOP
...@@ -35,7 +35,7 @@ SELECT f1(4); ...@@ -35,7 +35,7 @@ SELECT f1(4);
f1(4) f1(4)
2 2
DROP FUNCTION f1; DROP FUNCTION f1;
CREATE FUNCTION f1 (a INT) RETURNS INT CREATE FUNCTION f1 (a INT) RETURNS INT AS
BEGIN BEGIN
<<label1>> <<label1>>
WHILE a>0 DO WHILE a>0 DO
...@@ -51,7 +51,7 @@ SELECT f1(4); ...@@ -51,7 +51,7 @@ SELECT f1(4);
f1(4) f1(4)
2 2
DROP FUNCTION f1; DROP FUNCTION f1;
CREATE FUNCTION f1 (a INT) RETURNS INT CREATE FUNCTION f1 (a INT) RETURNS INT AS
BEGIN BEGIN
<<label1>> <<label1>>
REPEAT REPEAT
...@@ -68,7 +68,7 @@ f1(4) ...@@ -68,7 +68,7 @@ f1(4)
2 2
DROP FUNCTION f1; DROP FUNCTION f1;
# Testing IN/OUT/INOUT # Testing IN/OUT/INOUT
CREATE PROCEDURE p1 (p1 IN VARCHAR2(10), p2 OUT VARCHAR2(10)) CREATE PROCEDURE p1 (p1 IN VARCHAR2(10), p2 OUT VARCHAR2(10)) AS
BEGIN BEGIN
SET p1='p1new'; SET p1='p1new';
SET p2='p2new'; SET p2='p2new';
...@@ -81,7 +81,7 @@ SELECT @p1, @p2; ...@@ -81,7 +81,7 @@ SELECT @p1, @p2;
p1 p2new p1 p2new
DROP PROCEDURE p1; DROP PROCEDURE p1;
# Testing Oracle-style assigment # Testing Oracle-style assigment
CREATE PROCEDURE p1 (p1 OUT VARCHAR2(10)) CREATE PROCEDURE p1 (p1 OUT VARCHAR2(10)) AS
BEGIN BEGIN
p1:= 'p1new'; p1:= 'p1new';
END; END;
...@@ -93,138 +93,138 @@ SELECT @p1; ...@@ -93,138 +93,138 @@ SELECT @p1;
p1new p1new
DROP PROCEDURE p1; DROP PROCEDURE p1;
# Testing that (some) keyword_sp are allowed in Oracle-style assignments # Testing that (some) keyword_sp are allowed in Oracle-style assignments
CREATE PROCEDURE p1 (action OUT INT) action:=10; CREATE PROCEDURE p1 (action OUT INT) AS BEGIN action:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (clob OUT INT) clob:=10; CREATE PROCEDURE p1 (clob OUT INT) AS BEGIN clob:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (enum OUT INT) enum:=10; CREATE PROCEDURE p1 (enum OUT INT) AS BEGIN enum:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (via OUT INT) via:=10; CREATE PROCEDURE p1 (via OUT INT) AS BEGIN via:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
# Testing keyword_directly_assignable # Testing keyword_directly_assignable
CREATE PROCEDURE p1 (ascii OUT INT) ascii:=10; CREATE PROCEDURE p1 (ascii OUT INT) AS BEGIN ascii:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (backup OUT INT) backup:=10; CREATE PROCEDURE p1 (backup OUT INT) AS BEGIN backup:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (binlog OUT INT) binlog:=10; CREATE PROCEDURE p1 (binlog OUT INT) AS BEGIN binlog:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (byte OUT INT) byte:=10; CREATE PROCEDURE p1 (byte OUT INT) AS BEGIN byte:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (cache OUT INT) cache:=10; CREATE PROCEDURE p1 (cache OUT INT) AS BEGIN cache:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (checksum OUT INT) checksum:=10; CREATE PROCEDURE p1 (checksum OUT INT) AS BEGIN checksum:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (checkpoint OUT INT) checkpoint:=10; CREATE PROCEDURE p1 (checkpoint OUT INT) AS BEGIN checkpoint:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (column_add OUT INT) column_add:=10; CREATE PROCEDURE p1 (column_add OUT INT) AS BEGIN column_add:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (column_check OUT INT) column_check:=10; CREATE PROCEDURE p1 (column_check OUT INT) AS BEGIN column_check:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (column_create OUT INT) column_create:=10; CREATE PROCEDURE p1 (column_create OUT INT) AS BEGIN column_create:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (column_delete OUT INT) column_delete:=10; CREATE PROCEDURE p1 (column_delete OUT INT) AS BEGIN column_delete:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (column_get OUT INT) column_get:=10; CREATE PROCEDURE p1 (column_get OUT INT) AS BEGIN column_get:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (commit OUT INT) commit:=10; CREATE PROCEDURE p1 (commit OUT INT) AS BEGIN commit:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (deallocate OUT INT) deallocate:=10; CREATE PROCEDURE p1 (deallocate OUT INT) AS BEGIN deallocate:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (examined OUT INT) examined:=10; CREATE PROCEDURE p1 (examined OUT INT) AS BEGIN examined:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (execute OUT INT) execute:=10; CREATE PROCEDURE p1 (execute OUT INT) AS BEGIN execute:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (flush OUT INT) flush:=10; CREATE PROCEDURE p1 (flush OUT INT) AS BEGIN flush:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (format OUT INT) format:=10; CREATE PROCEDURE p1 (format OUT INT) AS BEGIN format:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (get OUT INT) get:=10; CREATE PROCEDURE p1 (get OUT INT) AS BEGIN get:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (help OUT INT) help:=10; CREATE PROCEDURE p1 (help OUT INT) AS BEGIN help:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (host OUT INT) host:=10; CREATE PROCEDURE p1 (host OUT INT) AS BEGIN host:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (install OUT INT) install:=10; CREATE PROCEDURE p1 (install OUT INT) AS BEGIN install:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (option OUT INT) option:=10; CREATE PROCEDURE p1 (option OUT INT) AS BEGIN option:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (options OUT INT) options:=10; CREATE PROCEDURE p1 (options OUT INT) AS BEGIN options:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (owner OUT INT) owner:=10; CREATE PROCEDURE p1 (owner OUT INT) AS BEGIN owner:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (parser OUT INT) parser:=10; CREATE PROCEDURE p1 (parser OUT INT) AS BEGIN parser:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (port OUT INT) port:=10; CREATE PROCEDURE p1 (port OUT INT) AS BEGIN port:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (prepare OUT INT) prepare:=10; CREATE PROCEDURE p1 (prepare OUT INT) AS BEGIN prepare:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (remove OUT INT) remove:=10; CREATE PROCEDURE p1 (remove OUT INT) AS BEGIN remove:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (reset OUT INT) reset:=10; CREATE PROCEDURE p1 (reset OUT INT) AS BEGIN reset:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (restore OUT INT) restore:=10; CREATE PROCEDURE p1 (restore OUT INT) AS BEGIN restore:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (rollback OUT INT) rollback:=10; CREATE PROCEDURE p1 (rollback OUT INT) AS BEGIN rollback:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (security OUT INT) security:=10; CREATE PROCEDURE p1 (security OUT INT) AS BEGIN security:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (server OUT INT) server:=10; CREATE PROCEDURE p1 (server OUT INT) AS BEGIN server:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (shutdown OUT INT) shutdown:=10; CREATE PROCEDURE p1 (shutdown OUT INT) AS BEGIN shutdown:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (signed OUT INT) signed:=10; CREATE PROCEDURE p1 (signed OUT INT) AS BEGIN signed:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (socket OUT INT) socket:=10; CREATE PROCEDURE p1 (socket OUT INT) AS BEGIN socket:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (slave OUT INT) slave:=10; CREATE PROCEDURE p1 (slave OUT INT) AS BEGIN slave:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (slaves OUT INT) slaves:=10; CREATE PROCEDURE p1 (slaves OUT INT) AS BEGIN slaves:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (soname OUT INT) soname:=10; CREATE PROCEDURE p1 (soname OUT INT) AS BEGIN soname:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (start OUT INT) start:=10; CREATE PROCEDURE p1 (start OUT INT) AS BEGIN start:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (stop OUT INT) stop:=10; CREATE PROCEDURE p1 (stop OUT INT) AS BEGIN stop:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (stored OUT INT) stored:=10; CREATE PROCEDURE p1 (stored OUT INT) AS BEGIN stored:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (unicode OUT INT) unicode:=10; CREATE PROCEDURE p1 (unicode OUT INT) AS BEGIN unicode:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (uninstall OUT INT) uninstall:=10; CREATE PROCEDURE p1 (uninstall OUT INT) AS BEGIN uninstall:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (upgrade OUT INT) upgrade:=10; CREATE PROCEDURE p1 (upgrade OUT INT) AS BEGIN upgrade:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (wrapper OUT INT) wrapper:=10; CREATE PROCEDURE p1 (wrapper OUT INT) AS BEGIN wrapper:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (xa OUT INT) xa:=10; CREATE PROCEDURE p1 (xa OUT INT) AS BEGIN xa:=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
# Testing that keyword_directly_not_assignable works in SET statements. # Testing that keyword_directly_not_assignable works in SET statements.
CREATE PROCEDURE p1 (contains OUT INT) SET contains=10; CREATE PROCEDURE p1 (contains OUT INT) AS BEGIN SET contains=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (language OUT INT) SET language=10; CREATE PROCEDURE p1 (language OUT INT) AS BEGIN SET language=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (no OUT INT) SET no=10; CREATE PROCEDURE p1 (no OUT INT) AS BEGIN SET no=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (charset OUT INT) SET charset=10; CREATE PROCEDURE p1 (charset OUT INT) AS BEGIN SET charset=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (do OUT INT) SET do=10; CREATE PROCEDURE p1 (do OUT INT) AS BEGIN SET do=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (repair OUT INT) SET repair=10; CREATE PROCEDURE p1 (repair OUT INT) AS BEGIN SET repair=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (handler OUT INT) SET handler=10; CREATE PROCEDURE p1 (handler OUT INT) AS BEGIN SET handler=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (open OUT INT) SET open=10; CREATE PROCEDURE p1 (open OUT INT) AS BEGIN SET open=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (close OUT INT) SET close=10; CREATE PROCEDURE p1 (close OUT INT) AS BEGIN SET close=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (savepoint OUT INT) SET savepoint=10; CREATE PROCEDURE p1 (savepoint OUT INT) AS BEGIN SET savepoint=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (truncate OUT INT) SET truncate=10; CREATE PROCEDURE p1 (truncate OUT INT) AS BEGIN SET truncate=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (begin OUT INT) SET begin=10; CREATE PROCEDURE p1 (begin OUT INT) AS BEGIN SET begin=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
CREATE PROCEDURE p1 (end OUT INT) SET end=10; CREATE PROCEDURE p1 (end OUT INT) AS BEGIN SET end=10; END;/
DROP PROCEDURE p1; DROP PROCEDURE p1/
# Testing that keyword_directly_not_assignable works in table/column names # Testing that keyword_directly_not_assignable works in table/column names
CREATE TABLE contains (contains INT); CREATE TABLE contains (contains INT);
DROP TABLE contains; DROP TABLE contains;
......
...@@ -3,7 +3,7 @@ SET sql_mode=ORACLE; ...@@ -3,7 +3,7 @@ SET sql_mode=ORACLE;
--echo # Testing labels --echo # Testing labels
DELIMITER /; DELIMITER /;
CREATE FUNCTION f1 (a INT) RETURNS CLOB CREATE FUNCTION f1 (a INT) RETURNS CLOB AS
BEGIN BEGIN
<<label1>> <<label1>>
BEGIN BEGIN
...@@ -22,7 +22,7 @@ DROP FUNCTION f1; ...@@ -22,7 +22,7 @@ DROP FUNCTION f1;
DELIMITER /; DELIMITER /;
CREATE FUNCTION f1 (a INT) RETURNS INT CREATE FUNCTION f1 (a INT) RETURNS INT IS
BEGIN BEGIN
<<label1>> <<label1>>
LOOP LOOP
...@@ -40,7 +40,7 @@ DROP FUNCTION f1; ...@@ -40,7 +40,7 @@ DROP FUNCTION f1;
DELIMITER /; DELIMITER /;
CREATE FUNCTION f1 (a INT) RETURNS INT CREATE FUNCTION f1 (a INT) RETURNS INT AS
BEGIN BEGIN
<<label1>> <<label1>>
WHILE a>0 DO WHILE a>0 DO
...@@ -58,7 +58,7 @@ DROP FUNCTION f1; ...@@ -58,7 +58,7 @@ DROP FUNCTION f1;
DELIMITER /; DELIMITER /;
CREATE FUNCTION f1 (a INT) RETURNS INT CREATE FUNCTION f1 (a INT) RETURNS INT AS
BEGIN BEGIN
<<label1>> <<label1>>
REPEAT REPEAT
...@@ -77,7 +77,7 @@ DROP FUNCTION f1; ...@@ -77,7 +77,7 @@ DROP FUNCTION f1;
--echo # Testing IN/OUT/INOUT --echo # Testing IN/OUT/INOUT
DELIMITER /; DELIMITER /;
CREATE PROCEDURE p1 (p1 IN VARCHAR2(10), p2 OUT VARCHAR2(10)) CREATE PROCEDURE p1 (p1 IN VARCHAR2(10), p2 OUT VARCHAR2(10)) AS
BEGIN BEGIN
SET p1='p1new'; SET p1='p1new';
SET p2='p2new'; SET p2='p2new';
...@@ -91,7 +91,7 @@ DROP PROCEDURE p1; ...@@ -91,7 +91,7 @@ DROP PROCEDURE p1;
--echo # Testing Oracle-style assigment --echo # Testing Oracle-style assigment
DELIMITER /; DELIMITER /;
CREATE PROCEDURE p1 (p1 OUT VARCHAR2(10)) CREATE PROCEDURE p1 (p1 OUT VARCHAR2(10)) AS
BEGIN BEGIN
p1:= 'p1new'; p1:= 'p1new';
END; END;
...@@ -103,141 +103,147 @@ SELECT @p1; ...@@ -103,141 +103,147 @@ SELECT @p1;
DROP PROCEDURE p1; DROP PROCEDURE p1;
--echo # Testing that (some) keyword_sp are allowed in Oracle-style assignments --echo # Testing that (some) keyword_sp are allowed in Oracle-style assignments
CREATE PROCEDURE p1 (action OUT INT) action:=10; DELIMITER /;
DROP PROCEDURE p1; CREATE PROCEDURE p1 (action OUT INT) AS BEGIN action:=10; END;/
CREATE PROCEDURE p1 (clob OUT INT) clob:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (clob OUT INT) AS BEGIN clob:=10; END;/
CREATE PROCEDURE p1 (enum OUT INT) enum:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (enum OUT INT) AS BEGIN enum:=10; END;/
CREATE PROCEDURE p1 (via OUT INT) via:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (via OUT INT) AS BEGIN via:=10; END;/
DROP PROCEDURE p1/
DELIMITER ;/
--echo # Testing keyword_directly_assignable --echo # Testing keyword_directly_assignable
CREATE PROCEDURE p1 (ascii OUT INT) ascii:=10; DELIMITER /;
DROP PROCEDURE p1; CREATE PROCEDURE p1 (ascii OUT INT) AS BEGIN ascii:=10; END;/
CREATE PROCEDURE p1 (backup OUT INT) backup:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (backup OUT INT) AS BEGIN backup:=10; END;/
CREATE PROCEDURE p1 (binlog OUT INT) binlog:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (binlog OUT INT) AS BEGIN binlog:=10; END;/
CREATE PROCEDURE p1 (byte OUT INT) byte:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (byte OUT INT) AS BEGIN byte:=10; END;/
CREATE PROCEDURE p1 (cache OUT INT) cache:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (cache OUT INT) AS BEGIN cache:=10; END;/
CREATE PROCEDURE p1 (checksum OUT INT) checksum:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (checksum OUT INT) AS BEGIN checksum:=10; END;/
CREATE PROCEDURE p1 (checkpoint OUT INT) checkpoint:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (checkpoint OUT INT) AS BEGIN checkpoint:=10; END;/
CREATE PROCEDURE p1 (column_add OUT INT) column_add:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (column_add OUT INT) AS BEGIN column_add:=10; END;/
CREATE PROCEDURE p1 (column_check OUT INT) column_check:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (column_check OUT INT) AS BEGIN column_check:=10; END;/
CREATE PROCEDURE p1 (column_create OUT INT) column_create:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (column_create OUT INT) AS BEGIN column_create:=10; END;/
CREATE PROCEDURE p1 (column_delete OUT INT) column_delete:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (column_delete OUT INT) AS BEGIN column_delete:=10; END;/
CREATE PROCEDURE p1 (column_get OUT INT) column_get:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (column_get OUT INT) AS BEGIN column_get:=10; END;/
CREATE PROCEDURE p1 (commit OUT INT) commit:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (commit OUT INT) AS BEGIN commit:=10; END;/
CREATE PROCEDURE p1 (deallocate OUT INT) deallocate:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (deallocate OUT INT) AS BEGIN deallocate:=10; END;/
CREATE PROCEDURE p1 (examined OUT INT) examined:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (examined OUT INT) AS BEGIN examined:=10; END;/
CREATE PROCEDURE p1 (execute OUT INT) execute:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (execute OUT INT) AS BEGIN execute:=10; END;/
CREATE PROCEDURE p1 (flush OUT INT) flush:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (flush OUT INT) AS BEGIN flush:=10; END;/
CREATE PROCEDURE p1 (format OUT INT) format:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (format OUT INT) AS BEGIN format:=10; END;/
CREATE PROCEDURE p1 (get OUT INT) get:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (get OUT INT) AS BEGIN get:=10; END;/
CREATE PROCEDURE p1 (help OUT INT) help:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (help OUT INT) AS BEGIN help:=10; END;/
CREATE PROCEDURE p1 (host OUT INT) host:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (host OUT INT) AS BEGIN host:=10; END;/
CREATE PROCEDURE p1 (install OUT INT) install:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (install OUT INT) AS BEGIN install:=10; END;/
CREATE PROCEDURE p1 (option OUT INT) option:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (option OUT INT) AS BEGIN option:=10; END;/
CREATE PROCEDURE p1 (options OUT INT) options:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (options OUT INT) AS BEGIN options:=10; END;/
CREATE PROCEDURE p1 (owner OUT INT) owner:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (owner OUT INT) AS BEGIN owner:=10; END;/
CREATE PROCEDURE p1 (parser OUT INT) parser:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (parser OUT INT) AS BEGIN parser:=10; END;/
CREATE PROCEDURE p1 (port OUT INT) port:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (port OUT INT) AS BEGIN port:=10; END;/
CREATE PROCEDURE p1 (prepare OUT INT) prepare:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (prepare OUT INT) AS BEGIN prepare:=10; END;/
CREATE PROCEDURE p1 (remove OUT INT) remove:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (remove OUT INT) AS BEGIN remove:=10; END;/
CREATE PROCEDURE p1 (reset OUT INT) reset:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (reset OUT INT) AS BEGIN reset:=10; END;/
CREATE PROCEDURE p1 (restore OUT INT) restore:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (restore OUT INT) AS BEGIN restore:=10; END;/
CREATE PROCEDURE p1 (rollback OUT INT) rollback:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (rollback OUT INT) AS BEGIN rollback:=10; END;/
CREATE PROCEDURE p1 (security OUT INT) security:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (security OUT INT) AS BEGIN security:=10; END;/
CREATE PROCEDURE p1 (server OUT INT) server:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (server OUT INT) AS BEGIN server:=10; END;/
CREATE PROCEDURE p1 (shutdown OUT INT) shutdown:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (shutdown OUT INT) AS BEGIN shutdown:=10; END;/
CREATE PROCEDURE p1 (signed OUT INT) signed:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (signed OUT INT) AS BEGIN signed:=10; END;/
CREATE PROCEDURE p1 (socket OUT INT) socket:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (socket OUT INT) AS BEGIN socket:=10; END;/
CREATE PROCEDURE p1 (slave OUT INT) slave:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (slave OUT INT) AS BEGIN slave:=10; END;/
CREATE PROCEDURE p1 (slaves OUT INT) slaves:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (slaves OUT INT) AS BEGIN slaves:=10; END;/
CREATE PROCEDURE p1 (soname OUT INT) soname:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (soname OUT INT) AS BEGIN soname:=10; END;/
CREATE PROCEDURE p1 (start OUT INT) start:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (start OUT INT) AS BEGIN start:=10; END;/
CREATE PROCEDURE p1 (stop OUT INT) stop:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (stop OUT INT) AS BEGIN stop:=10; END;/
CREATE PROCEDURE p1 (stored OUT INT) stored:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (stored OUT INT) AS BEGIN stored:=10; END;/
CREATE PROCEDURE p1 (unicode OUT INT) unicode:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (unicode OUT INT) AS BEGIN unicode:=10; END;/
CREATE PROCEDURE p1 (uninstall OUT INT) uninstall:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (uninstall OUT INT) AS BEGIN uninstall:=10; END;/
CREATE PROCEDURE p1 (upgrade OUT INT) upgrade:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (upgrade OUT INT) AS BEGIN upgrade:=10; END;/
CREATE PROCEDURE p1 (wrapper OUT INT) wrapper:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (wrapper OUT INT) AS BEGIN wrapper:=10; END;/
CREATE PROCEDURE p1 (xa OUT INT) xa:=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (xa OUT INT) AS BEGIN xa:=10; END;/
DROP PROCEDURE p1/
DELIMITER ;/
--echo # Testing that keyword_directly_not_assignable works in SET statements. --echo # Testing that keyword_directly_not_assignable works in SET statements.
CREATE PROCEDURE p1 (contains OUT INT) SET contains=10; DELIMITER /;
DROP PROCEDURE p1; CREATE PROCEDURE p1 (contains OUT INT) AS BEGIN SET contains=10; END;/
CREATE PROCEDURE p1 (language OUT INT) SET language=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (language OUT INT) AS BEGIN SET language=10; END;/
CREATE PROCEDURE p1 (no OUT INT) SET no=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (no OUT INT) AS BEGIN SET no=10; END;/
CREATE PROCEDURE p1 (charset OUT INT) SET charset=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (charset OUT INT) AS BEGIN SET charset=10; END;/
CREATE PROCEDURE p1 (do OUT INT) SET do=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (do OUT INT) AS BEGIN SET do=10; END;/
CREATE PROCEDURE p1 (repair OUT INT) SET repair=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (repair OUT INT) AS BEGIN SET repair=10; END;/
CREATE PROCEDURE p1 (handler OUT INT) SET handler=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (handler OUT INT) AS BEGIN SET handler=10; END;/
CREATE PROCEDURE p1 (open OUT INT) SET open=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (open OUT INT) AS BEGIN SET open=10; END;/
CREATE PROCEDURE p1 (close OUT INT) SET close=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (close OUT INT) AS BEGIN SET close=10; END;/
CREATE PROCEDURE p1 (savepoint OUT INT) SET savepoint=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (savepoint OUT INT) AS BEGIN SET savepoint=10; END;/
CREATE PROCEDURE p1 (truncate OUT INT) SET truncate=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (truncate OUT INT) AS BEGIN SET truncate=10; END;/
CREATE PROCEDURE p1 (begin OUT INT) SET begin=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (begin OUT INT) AS BEGIN SET begin=10; END;/
CREATE PROCEDURE p1 (end OUT INT) SET end=10; DROP PROCEDURE p1/
DROP PROCEDURE p1; CREATE PROCEDURE p1 (end OUT INT) AS BEGIN SET end=10; END;/
DROP PROCEDURE p1/
DELIMITER ;/
--echo # Testing that keyword_directly_not_assignable works in table/column names --echo # Testing that keyword_directly_not_assignable works in table/column names
CREATE TABLE contains (contains INT); CREATE TABLE contains (contains INT);
......
...@@ -16131,7 +16131,8 @@ sf_tail: ...@@ -16131,7 +16131,8 @@ sf_tail:
lex->sphead->set_body_start(thd, lip->get_cpp_tok_start()); lex->sphead->set_body_start(thd, lip->get_cpp_tok_start());
} }
sp_proc_stmt_in_returns_clause /* $15 */ sp_tail_is /* $15 */
sp_proc_stmt_in_returns_clause /* $16 */
{ {
LEX *lex= thd->lex; LEX *lex= thd->lex;
sp_head *sp= lex->sphead; sp_head *sp= lex->sphead;
...@@ -16179,6 +16180,7 @@ sp_tail: ...@@ -16179,6 +16180,7 @@ sp_tail:
{ {
Lex->sphead->set_body_start(thd, YYLIP->get_cpp_tok_start()); Lex->sphead->set_body_start(thd, YYLIP->get_cpp_tok_start());
} }
sp_tail_is
sp_proc_stmt sp_proc_stmt
{ {
LEX *lex= Lex; LEX *lex= Lex;
...@@ -16190,6 +16192,11 @@ sp_tail: ...@@ -16190,6 +16192,11 @@ sp_tail:
} }
; ;
sp_tail_is:
IS
| AS
;
/*************************************************************************/ /*************************************************************************/
xa: xa:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment