日期:2014-05-16  浏览次数:20886 次

MySQL 5.0 新特征教程 存储进程:第二讲
  Why MySQL Statements are Legal in a Procedure Body
  什么MySQL语句在存储进程体中是正当的?


  什么样的SQL语句在Mysql存储进程中才是正当的呢?你可以创立一个包括INSERT, UPDATE,DELETE, SELECT, DROP, CREATE, REPLACE等的语句。你唯一需求记着的是假定代码中包括MySQL扩展成效,那么代码将不能移植。在模范模范SQL语句中:任何数据库界说说话都是正当的,如:





CREATE PROCEDURE p () DELETE FROM t; //
  SET、COMMIT以及ROLLBACK也是正当的,如:
CREATE PROCEDURE p () SET @x = 5; //


  MySQL的附加成效:任何数据操作说话的语句都将正当。
CREATE PROCEDURE p () DROP TABLE t; //


  MySQL扩展成效:间接的SELECT也是正当的:
CREATE PROCEDURE p () SELECT 'a'; //


  专程提一下,我将存储进程中包括DDL语句的成效称为MySQL附加成效的缘由是在SQL模范模范中把这个界说为非核心的,即可选组件。


  在进程体中有一个束缚,就是不能有对例程或表操作的数据库操作语句。例如下面的例子便是非法的:
CREATE PROCEDURE p1 ()
CREATE PROCEDURE p2 () DELETE FROM t; //


  下面这些对MySQL 5.0来说全新的语句,进程体中是非法的:
CREATE PROCEDURE, ALTER PROCEDURE, DROP PROCEDURE, CREATE FUNCTION,
DROP FUNCTION, CREATE TRIGGER, DROP TRIGGER.


  不过你可以利用
CREATE PROCEDURE db5.p1 () DROP DATABASE db5//


  然则沟通
"USE database"


  语句也是非法的,由于MySQL假定默许数据库就是进程的事情场所。


  Call the Procedure 调用存储进程
  1.
  如今我们就可以调用一个存储进程了,你所需求输出的全部就是CALL和你进程名以及一个括号再一次夸大,括号是必须确当你调用例子外面的p1进程时,成就是屏幕前往了t表的内容
mysql> CALL p1() //
------
| s1 |
------
| 5 |
------
1 row in set (0.03 sec)
Query OK, 0 rows affected (0.03 sec)


  由于进程中的语句是
"SELECT * FROM t;"


  2. Let me say that again, another way.
  其他完成体例
mysql> CALL p1() //


  和下面语句的执行成就一样:
mysql> SELECT * FROM t; //


  以是,你调用p1进程就相称于你执行了下面语句:
"SELECT * FROM t;"


  好了,垂危的常识点"创立和调用进程办法"已经明白了。我进展你能对自身说这相称朴实。然则很快我们就有一系列的训练,每次都加一条子句,大体改动已经存在的子句。那样在写庞大部件前我们将会有良多可用的子句。


Characteristics Clauses 特征子句
  1.
CREATE PROCEDURE p2 ()
LANGUAGE SQL <--
NOT DETERMINISTIC <--
SQL SECURITY DEFINER <--
COMMENT 'A Procedure' <--
SELECT CURRENT_DATE, RAND() FROM t //


  这里我给出的是一些能反响存储进程特征的子句。子句内容在括号之后,主体之前。这些子句都是可选的,他们有什么感化呢?


  2.
CREATE PROCEDURE p2 ()
LANGUAGE SQL <--
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT 'A Procedure'
SELECT CURRENT_DATE, RAND() FROM t //


  很好,这个LANGUAGE SQL子句是没有感化的。仅是为了剖析');下面进程的主体利用SQL说话编写。这条是系统默许的,但你在这里声明是有效的,由于某些DBMS(IBM的DB2)需求它,假定你关注DB2的兼容成就最好还是用上。此外,当前大体味呈现除SQL外的其他说话撑持的存储进程。


  3.
CREATE PROCEDURE p2 ()
LANGUAGE SQL
NOT DETERMINISTIC <--
SQL SECURITY DEFINER
COMMENT 'A Procedure'
SELECT CURRENT_DATE, RAND() FROM t //


  下一个子句,NOT DETERMINISTIC,是传递给系统的信息。这里一个确定进程的界说就是那些每次输出一样输出也一样的挨次。在这个案例中,既然主体中含有SELECT语句,那前往肯定是未知的因而我们称其NOT DETERMINISTIC。然则MySQL内置的优化挨次不会细心这个,至少在如今不细心。


  4.
CREATE PROCEDURE p2 ()
LANGUAGE SQL
NOT DETERMINISTIC
SQL SECURITY DEFINER <--
COMMENT 'A Procedure'
SELECT CURRENT_DATE, RAND() FROM t //
  下一个子句是SQL SECURITY,可以界说为SQL SECURITY DEFINER或SQL SECURITY INVOKER。
  这就进入了权限控制的领域了,固然我们在前面将会有测试权限的例子。
SQL SECURITY DEFINER


  意味着在调用时搜索创立进程用户的权限(另一个选项是SQLSECURITY INVOKER)。
  如今而言,利用
SQL SECURITY DEFINER


  指令通知MySQL效劳器搜索创立进程的用户就可以了,当进程已经被调用,就不搜索执行调用进程的用户了。而另一个选项(INVOKER)则是通知效劳器在这一步仍然要搜索调用者的权限。


  5.
CREATE PROCEDURE p2 ()
LANGUAGE SQL
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT 'A Procedure' <--
SELECT CURRENT_DATE, RAND() FROM t //


  COMMENT 'A procedure'
  是一个可选的正文剖析');。


  最初,正文子句会跟进程界说存储在一同。这个没有巩固的模范模范,我在文中会指出没有巩固模范模范的语句,不过侥幸的是这些在我们模范模范的SQL中很少。


  6.
CREATE PROCEDURE p2 ()
LANGUAGE SQL
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT ''
SELECT