MySQL 5.0 新特性教程 存储进程:第二讲

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

MySQL 5.0 新特性教程 存储进程:第二讲

相关文章:

你感兴趣的文章:

标签云: