summaryrefslogtreecommitdiff
path: root/Docs
diff options
context:
space:
mode:
authorunknown <pem@mysql.com>2003-03-03 15:03:19 +0100
committerunknown <pem@mysql.com>2003-03-03 15:03:19 +0100
commitf519382d2bf276a9beb5d123fde93ec4cdfdefea (patch)
tree8f6f25b0c7c17695dfba611a482a1bde83285372 /Docs
parent8a9422bd2af6ea39676171b9ec16897c64104dc8 (diff)
downloadmariadb-git-f519382d2bf276a9beb5d123fde93ec4cdfdefea.tar.gz
New FUNCTION documentation, and a minor test case modification.
Docs/sp-imp-spec.txt: Updated docs about stored FUNCTIONs. Docs/sp-implemented.txt: Updated docs about stored FUNCTIONs. mysql-test/r/sp.result: Changed the ifac test example into a combination of a procedure and a function. mysql-test/t/sp.test: Changed the ifac test example into a combination of a procedure and a function.
Diffstat (limited to 'Docs')
-rw-r--r--Docs/sp-imp-spec.txt64
-rw-r--r--Docs/sp-implemented.txt25
2 files changed, 80 insertions, 9 deletions
diff --git a/Docs/sp-imp-spec.txt b/Docs/sp-imp-spec.txt
index 198623a0f5b..c3818f141dc 100644
--- a/Docs/sp-imp-spec.txt
+++ b/Docs/sp-imp-spec.txt
@@ -172,8 +172,9 @@ calling a PROCEDURE.
with the addition that a FUNCTION has a return type and a RETURN
statement, but no OUT or INOUT parameters.
- [QQ - More details here; sp_head needs a result slot and a type flag
- indicating if it's a function or procedure]
+ The main difference during parsing is that we store the result type
+ in the sp_head. However, there are big differences when it comes to
+ invoking a FUNCTION. (See below.)
- Storing, caching, dropping...
@@ -273,7 +274,64 @@ calling a PROCEDURE.
So, stored functions must be handled in a simpilar way, and as a
consequence, UDFs and functions must not have the same name.
- [QQ - Details of how function calls works here]
+ - Detecting and parsing a FUNCTION invokation
+
+ The existance of UDFs are checked during the lexical analysis (in
+ sql_lex.cc:find_keyword()). This has the drawback that they must
+ exist before they are refered to, which was ok before SPs existed,
+ but then it becomes a problem. The first implementation of SP FUNCTIONs
+ will work the same way, but this should be fixed a.s.a.p. (This will
+ required some reworking of the way UDFs are handled, which is why it's
+ not done from the start.)
+ For the time being, a FUNCTION is detected the same way, and returns
+ the token SP_FUNC. During the parsing we only check for the *existance*
+ of the function, we don't parse it, since wa can't call the parser
+ recursively.
+
+ When encountering a SP_FUNC with parameters in the expression parser,
+ an instance of the new Item_func_sp class is created. Unlike UDFs, we
+ don't have different classes for different return types, since we at
+ this point don't know the type.
+
+ - Collecting FUNCTIONs to invoke
+
+ A FUNCTION differs from a PROCEDURE in one important aspect: Whereas a
+ PROCEDURE is CALLed as statement by itself, a FUNCTION is invoked
+ "on-the-fly" during the execution of *another* statement.
+ This makes things a lot more complicated compared to CALL:
+ - We can't read and parse the FUNCTION from the mysql.proc table at the
+ point of invokation; the server requires that all tables used are
+ opened and locked at the beginning of the query execution.
+ One "obvious" solution would be to simply push "mysql.proc" to the list
+ of tables used by the query, but this implies a "join" with this table
+ if the query is a select, so it doesn't work (and we can't exclude this
+ table easily; since a priviledged used might in fact want to search
+ the proc table).
+ Another solution would of course be to allow the opening and closing
+ of the mysql.proc table during a query execution, but this it not
+ possible at the present.
+
+ So, the solution is to collect the names of the refered FUNCTIONs during
+ parsing in the lex.
+ Then, before doing anything else in mysql_execute_command(), read all
+ functions from the database an keep them in the THD, where the function
+ sp_find_function() can find them during the execution.
+ Note: Even when a global in-memory cache is implemented, we must still
+ make sure that the functions are indeed read and cached at this point.
+ The code that read and cache functions from the database must also be
+ invoked recursively for each read FUNCTION to make sure we have *all* the
+ functions we need.
+
+ In the absence of the real in-memory cache for SPs, a temporary solution
+ has been implemented with a per-THD cache for just FUNCTIONs. This is
+ handled by the functions
+
+ void sp_add_fun_to_lex(LEX *lex, LEX_STRING fun);
+ void sp_merge_funs(LEX *dst, LEX *src);
+ int sp_cache_functions(THD *thd, LEX *lex);
+ void sp_clear_function_cache(THD *thd);
+
+ in sp.cc.
- Parsing DROP PROCEDURE/FUNCTION
diff --git a/Docs/sp-implemented.txt b/Docs/sp-implemented.txt
index b3b12b7edb8..5173606e95c 100644
--- a/Docs/sp-implemented.txt
+++ b/Docs/sp-implemented.txt
@@ -3,7 +3,6 @@ Stored Procedures implemented 2003-02-02:
Summary of Not Yet Implemented:
- - FUNCTIONs
- Routine characteristics
- External languages
- Access control
@@ -26,14 +25,14 @@ Summary of what's implemented:
List of what's implemented:
- - CREATE PROCEDURE name ( args ) body
+ - CREATE PROCEDURE|FUNCTION name ( args ) body
No routine characteristics yet.
- - ALTER PROCEDURE name ...
+ - ALTER PROCEDURE|FUNCTION name ...
Is parsed, but a no-op (as there are no characteristics implemented yet).
CASCADE/RESTRICT is not implemented (and CASCADE probably will not be).
- - DROP PROCEDURE name
+ - DROP PROCEDURE|FUNCTION name
CASCADE/RESTRICT is not implemented (and CASCADE probably will not be).
- CALL name (args)
@@ -45,7 +44,7 @@ List of what's implemented:
will either generate an error message, or it might even work to
call all procedures from the top-level.
- - Procedure body:
+ - Function/Procedure body:
- BEGIN/END
Is parsed, but not the real thing with (optional) transaction
control, it only serves as block syntax for multiple statements (and
@@ -82,9 +81,23 @@ Closed questions:
Answer: Same tables, with an additional key-field for the type.
-Open questions:
+Open questions/issues:
- SQL-99 variables and parameters are typed. For the present we don't do
any type checking, since this is the way MySQL works. I still don't know
if we should keep it this way, or implement type checking. Possibly we
should have optional, uset-settable, type checking.
+
+ - FUNCTIONs do not work correctly in all circumstances yet.
+ For instance a function like:
+ create function s() returns int
+ begin
+ declare s int;
+ select sum(test.t.y) into s from test.t;
+ return s;
+ end
+ do not work. Invoking this in queries like "SELECT * FROM t2 WHERE x = s()"
+ will make things very complicated. And, in fact, even "SET @s=s()" and
+ "SELECT s()" fail, although the exact reasons in these cases are a bit
+ obscure; part of the problem might be the way the lex structure is
+ bit-copied (a not completely sound thing to do).