mirror of
https://github.com/MariaDB/server.git
synced 2025-05-31 08:42:45 +03:00
Part 13: RETURN vs RETURNS in function definition: CREATE FUNCTION f1(a INT) RETURN INT ... Part 12: No parentheses if no arguments: CREATE FUNCTION f1 RETURN INT ...
447 lines
10 KiB
Plaintext
447 lines
10 KiB
Plaintext
SET sql_mode=ORACLE;
|
|
# Testing routines with no parameters
|
|
CREATE FUNCTION f1 RETURN INT
|
|
AS
|
|
BEGIN
|
|
RETURN 10;
|
|
END;
|
|
/
|
|
SHOW CREATE FUNCTION f1;
|
|
Function f1
|
|
sql_mode PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,ORACLE,NO_KEY_OPTIONS,NO_TABLE_OPTIONS,NO_FIELD_OPTIONS,NO_AUTO_CREATE_USER
|
|
Create Function CREATE DEFINER="root"@"localhost" FUNCTION "f1"() RETURN int(11)
|
|
AS
|
|
BEGIN
|
|
RETURN 10;
|
|
END
|
|
character_set_client latin1
|
|
collation_connection latin1_swedish_ci
|
|
Database Collation latin1_swedish_ci
|
|
SELECT f1();
|
|
f1()
|
|
10
|
|
DROP FUNCTION f1;
|
|
CREATE PROCEDURE p1
|
|
AS
|
|
BEGIN
|
|
SET @a=10;
|
|
END;
|
|
/
|
|
SHOW CREATE PROCEDURE p1;
|
|
Procedure p1
|
|
sql_mode PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,ORACLE,NO_KEY_OPTIONS,NO_TABLE_OPTIONS,NO_FIELD_OPTIONS,NO_AUTO_CREATE_USER
|
|
Create Procedure CREATE DEFINER="root"@"localhost" PROCEDURE "p1"()
|
|
AS
|
|
BEGIN
|
|
SET @a=10;
|
|
END
|
|
character_set_client latin1
|
|
collation_connection latin1_swedish_ci
|
|
Database Collation latin1_swedish_ci
|
|
SET @a=0;
|
|
CALL p1();
|
|
SELECT @a;
|
|
@a
|
|
10
|
|
DROP PROCEDURE p1;
|
|
# Testing ":=" to set the default value of a variable
|
|
CREATE FUNCTION f1 () RETURN NUMBER(10) AS
|
|
a NUMBER(10) := 10;
|
|
BEGIN
|
|
DECLARE
|
|
b NUMBER(10) DEFAULT 3;
|
|
BEGIN
|
|
RETURN a+b;
|
|
END;
|
|
END;
|
|
/
|
|
SELECT f1();
|
|
f1()
|
|
13
|
|
DROP FUNCTION f1;
|
|
# Testing labels
|
|
CREATE FUNCTION f1 (a INT) RETURN CLOB AS
|
|
BEGIN
|
|
<<label1>>
|
|
BEGIN
|
|
IF a = 1 THEN
|
|
LEAVE label1;
|
|
END IF;
|
|
RETURN 'IS NOT 1';
|
|
END label1;
|
|
RETURN 'IS 1';
|
|
END;
|
|
/
|
|
SELECT f1(1);
|
|
f1(1)
|
|
IS 1
|
|
SELECT f1(2);
|
|
f1(2)
|
|
IS NOT 1
|
|
DROP FUNCTION f1;
|
|
CREATE FUNCTION f1 (a INT) RETURN INT IS
|
|
BEGIN
|
|
<<label1>>
|
|
LOOP
|
|
IF a = 2 THEN
|
|
LEAVE label1;
|
|
END IF;
|
|
SET a= a-1;
|
|
END LOOP;
|
|
RETURN a;
|
|
END;
|
|
/
|
|
SELECT f1(4);
|
|
f1(4)
|
|
2
|
|
DROP FUNCTION f1;
|
|
CREATE FUNCTION f1 (a INT) RETURN INT AS
|
|
BEGIN
|
|
<<label1>>
|
|
WHILE a>0 DO
|
|
IF a = 2 THEN
|
|
LEAVE label1;
|
|
END IF;
|
|
SET a= a-1;
|
|
END WHILE label1;
|
|
RETURN a;
|
|
END;
|
|
/
|
|
SELECT f1(4);
|
|
f1(4)
|
|
2
|
|
DROP FUNCTION f1;
|
|
CREATE FUNCTION f1 (a INT) RETURN INT AS
|
|
BEGIN
|
|
<<label1>>
|
|
REPEAT
|
|
IF a = 2 THEN
|
|
LEAVE label1;
|
|
END IF;
|
|
SET a= a-1;
|
|
UNTIL a=0 END REPEAT;
|
|
RETURN a;
|
|
END;
|
|
/
|
|
SELECT f1(4);
|
|
f1(4)
|
|
2
|
|
DROP FUNCTION f1;
|
|
# Testing IN/OUT/INOUT
|
|
CREATE PROCEDURE p1 (p1 IN VARCHAR2(10), p2 OUT VARCHAR2(10)) AS
|
|
BEGIN
|
|
SET p1='p1new';
|
|
SET p2='p2new';
|
|
END;
|
|
/
|
|
SET @p1='p1', @p2='p2';
|
|
CALL p1(@p1, @p2);
|
|
SELECT @p1, @p2;
|
|
@p1 @p2
|
|
p1 p2new
|
|
DROP PROCEDURE p1;
|
|
# Testing Oracle-style assigment
|
|
CREATE PROCEDURE p1 (p1 OUT VARCHAR2(10)) AS
|
|
BEGIN
|
|
p1:= 'p1new';
|
|
END;
|
|
/
|
|
SET @p1='p1';
|
|
CALL p1(@p1);
|
|
SELECT @p1;
|
|
@p1
|
|
p1new
|
|
DROP PROCEDURE p1;
|
|
# Testing that NULL is a valid statement
|
|
CREATE PROCEDURE p1(a INT) AS
|
|
BEGIN
|
|
NULL;
|
|
END;
|
|
/
|
|
DROP PROCEDURE p1;
|
|
CREATE PROCEDURE p1(a INT) AS
|
|
a INT:=10;
|
|
BEGIN
|
|
IF a=10 THEN NULL; ELSE NULL; END IF;
|
|
END;
|
|
/
|
|
DROP PROCEDURE p1;
|
|
# Testing that (some) keyword_sp are allowed in Oracle-style assignments
|
|
CREATE PROCEDURE p1 (action OUT INT) AS BEGIN action:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (clob OUT INT) AS BEGIN clob:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (enum OUT INT) AS BEGIN enum:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (via OUT INT) AS BEGIN via:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
# Testing keyword_directly_assignable
|
|
CREATE PROCEDURE p1 (ascii OUT INT) AS BEGIN ascii:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (backup OUT INT) AS BEGIN backup:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (binlog OUT INT) AS BEGIN binlog:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (byte OUT INT) AS BEGIN byte:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (cache OUT INT) AS BEGIN cache:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (checksum OUT INT) AS BEGIN checksum:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (checkpoint OUT INT) AS BEGIN checkpoint:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (column_add OUT INT) AS BEGIN column_add:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (column_check OUT INT) AS BEGIN column_check:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (column_create OUT INT) AS BEGIN column_create:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (column_delete OUT INT) AS BEGIN column_delete:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (column_get OUT INT) AS BEGIN column_get:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (commit OUT INT) AS BEGIN commit:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (deallocate OUT INT) AS BEGIN deallocate:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (examined OUT INT) AS BEGIN examined:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (execute OUT INT) AS BEGIN execute:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (flush OUT INT) AS BEGIN flush:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (format OUT INT) AS BEGIN format:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (get OUT INT) AS BEGIN get:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (help OUT INT) AS BEGIN help:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (host OUT INT) AS BEGIN host:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (install OUT INT) AS BEGIN install:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (option OUT INT) AS BEGIN option:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (options OUT INT) AS BEGIN options:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (owner OUT INT) AS BEGIN owner:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (parser OUT INT) AS BEGIN parser:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (port OUT INT) AS BEGIN port:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (prepare OUT INT) AS BEGIN prepare:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (remove OUT INT) AS BEGIN remove:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (reset OUT INT) AS BEGIN reset:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (restore OUT INT) AS BEGIN restore:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (rollback OUT INT) AS BEGIN rollback:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (security OUT INT) AS BEGIN security:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (server OUT INT) AS BEGIN server:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (shutdown OUT INT) AS BEGIN shutdown:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (signed OUT INT) AS BEGIN signed:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (socket OUT INT) AS BEGIN socket:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (slave OUT INT) AS BEGIN slave:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (slaves OUT INT) AS BEGIN slaves:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (soname OUT INT) AS BEGIN soname:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (start OUT INT) AS BEGIN start:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (stop OUT INT) AS BEGIN stop:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (stored OUT INT) AS BEGIN stored:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (unicode OUT INT) AS BEGIN unicode:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (uninstall OUT INT) AS BEGIN uninstall:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (upgrade OUT INT) AS BEGIN upgrade:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (wrapper OUT INT) AS BEGIN wrapper:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (xa OUT INT) AS BEGIN xa:=10; END;/
|
|
DROP PROCEDURE p1/
|
|
# Testing that keyword_directly_not_assignable works in SET statements.
|
|
CREATE PROCEDURE p1 (contains OUT INT) AS BEGIN SET contains=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (language OUT INT) AS BEGIN SET language=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (no OUT INT) AS BEGIN SET no=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (charset OUT INT) AS BEGIN SET charset=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (do OUT INT) AS BEGIN SET do=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (repair OUT INT) AS BEGIN SET repair=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (handler OUT INT) AS BEGIN SET handler=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (open OUT INT) AS BEGIN SET open=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (close OUT INT) AS BEGIN SET close=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (savepoint OUT INT) AS BEGIN SET savepoint=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (truncate OUT INT) AS BEGIN SET truncate=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (begin OUT INT) AS BEGIN SET begin=10; END;/
|
|
DROP PROCEDURE p1/
|
|
CREATE PROCEDURE p1 (end OUT INT) AS BEGIN SET end=10; END;/
|
|
DROP PROCEDURE p1/
|
|
# Testing that keyword_directly_not_assignable works in table/column names
|
|
CREATE TABLE contains (contains INT);
|
|
DROP TABLE contains;
|
|
CREATE TABLE language (language INT);
|
|
DROP TABLE language;
|
|
CREATE TABLE no (no INT);
|
|
DROP TABLE no;
|
|
CREATE TABLE charset (charset INT);
|
|
DROP TABLE charset;
|
|
CREATE TABLE do (do INT);
|
|
DROP TABLE do;
|
|
CREATE TABLE repair (repair INT);
|
|
DROP TABLE repair;
|
|
CREATE TABLE handler (handler INT);
|
|
DROP TABLE handler;
|
|
CREATE TABLE open (open INT);
|
|
DROP TABLE open;
|
|
CREATE TABLE close (close INT);
|
|
DROP TABLE close;
|
|
CREATE TABLE savepoint (savepoint INT);
|
|
DROP TABLE savepoint;
|
|
CREATE TABLE truncate (truncate INT);
|
|
DROP TABLE truncate;
|
|
CREATE TABLE begin (begin INT);
|
|
DROP TABLE begin;
|
|
CREATE TABLE end (end INT);
|
|
DROP TABLE end;
|
|
# Testing top-level declarations
|
|
CREATE PROCEDURE p1 (p1 OUT VARCHAR2(10))
|
|
AS
|
|
p2 VARCHAR(10);
|
|
BEGIN
|
|
p2:='p1new';
|
|
p1:=p2;
|
|
END;
|
|
/
|
|
SET @p1='p1';
|
|
CALL p1(@p1);
|
|
SELECT @p1;
|
|
@p1
|
|
p1new
|
|
DROP PROCEDURE p1;
|
|
CREATE FUNCTION f1 (p1 VARCHAR2(10)) RETURN VARCHAR(20)
|
|
AS
|
|
p2 VARCHAR(10);
|
|
BEGIN
|
|
p2:='new';
|
|
RETURN CONCAT(p1, p2);
|
|
END;
|
|
/
|
|
SET @p1='p1';
|
|
SELECT f1(@p1);
|
|
f1(@p1)
|
|
p1new
|
|
DROP FUNCTION f1;
|
|
# Testing non-top declarations
|
|
CREATE PROCEDURE p1 (p1 OUT VARCHAR2(10))
|
|
AS
|
|
BEGIN
|
|
DECLARE
|
|
p2 VARCHAR(10);
|
|
BEGIN
|
|
p2:='p1new';
|
|
p1:=p2;
|
|
END;
|
|
DECLARE
|
|
t1 VARCHAR(10);
|
|
t2 VARCHAR(10);
|
|
BEGIN
|
|
END;
|
|
END;
|
|
/
|
|
SET @p1='p1';
|
|
CALL p1(@p1);
|
|
SELECT @p1;
|
|
@p1
|
|
p1new
|
|
DROP PROCEDURE p1;
|
|
CREATE FUNCTION f1 (p1 VARCHAR2(10)) RETURN VARCHAR(20)
|
|
AS
|
|
BEGIN
|
|
DECLARE
|
|
p2 VARCHAR(10);
|
|
BEGIN
|
|
p2:='new';
|
|
RETURN CONCAT(p1, p2);
|
|
END;
|
|
DECLARE
|
|
t1 VARCHAR(10);
|
|
t2 VARCHAR(10);
|
|
BEGIN
|
|
END;
|
|
END;
|
|
/
|
|
SET @p1='p1';
|
|
SELECT f1(@p1);
|
|
f1(@p1)
|
|
p1new
|
|
DROP FUNCTION f1;
|
|
# Testing BEGIN NOT ATOMIC with no declarations
|
|
BEGIN NOT ATOMIC
|
|
SELECT 1 AS a;
|
|
END
|
|
/
|
|
a
|
|
1
|
|
# Testing BEGIN NOT ATOMIC with declarations
|
|
# DECLARE starts a new block and thus must be followed by BEGIN .. END
|
|
BEGIN NOT ATOMIC
|
|
DECLARE
|
|
i INT DEFAULT 5;
|
|
x INT DEFAULT 10;
|
|
BEGIN
|
|
<<label>>
|
|
WHILE i > 3 DO
|
|
i:= i - 1;
|
|
SELECT i;
|
|
END WHILE label;
|
|
END;
|
|
END
|
|
/
|
|
i
|
|
4
|
|
i
|
|
3
|
|
# Testing exceptions
|
|
CREATE TABLE t1 (c1 INT);
|
|
CREATE PROCEDURE sp1 (p1 IN VARCHAR2(20), p2 OUT VARCHAR2(30))
|
|
IS
|
|
v1 INT;
|
|
BEGIN
|
|
EXCEPTION WHEN NOT FOUND THEN
|
|
BEGIN
|
|
p2 := 'def';
|
|
END;
|
|
SELECT c1 INTO v1 FROM t1;
|
|
p2 := p1;
|
|
END;
|
|
/
|
|
CALL sp1('abc', @a);
|
|
SELECT @a;
|
|
@a
|
|
def
|
|
DROP PROCEDURE sp1;
|
|
DROP TABLE t1;
|