`
xiaohua2125
  • 浏览: 33391 次
  • 性别: Icon_minigender_1
  • 来自: 石家庄
社区版块
存档分类
最新评论

MySQL与存储过程

阅读更多

MySQL是“世界上最为流行的开放性数据库”,至少对于MySQL Web站点会这样。但无论MySQL如此流行,很多公司都对MySQL的使用抱有抵触情绪。这种现象来自几个原因,其中有些人错误地认为开放性源代码只不过相当于小孩子的积木游戏,而另一些人认为任何免费的东西都不会是好东西。也许这些想法都是误解,然而有一种抱怨却是合理的,即与其它对应的产品不一样,比如Oracle或者 DB2,MySQL不能够支持存储过程(stored procedures)。最新的MySQL 5.0能够支持存储过程。如果你对存储过程还没有熟悉,那么你可以认为它们只是存储在数据库服务器端的SQL命令和程序逻辑的集合。这些存储过程可以被应用程序调用,使得不同技术水平的开发人员能够建立自己的SQL。

优点
存储过程能够允许绝大部分的数据库访问逻辑与程序逻辑分离开来。使用存储过程的其中一个间接的优点是,程序的代码变得更加小巧和容易理解。存储过程的另一优点是,SQL可以被预先编译,由此提高了程序的速度。因为存储过程包含程序逻辑,可以在数据库服务器端更多地执行更多的处理。同样,当执行一个n-tier程序时,存储过程被用于将数据层与服务层分离开来。

安全性也是存储过程的另一优点。当不能直接访问表格时,程序可以将执行优先级别分配给存储过程。不幸的是,在这时候,MySQL不支持“授予执行(GRANT EXECUTE)”。这就意味着除非程序具有访问表格的权限,否则调用访问相同表格的一个存储过程也是不行的。使用这一特性有点像在做一个很有趣的。

标准
与Oracle或者微软的相关数据库不一样,MySQL和IBM的DB2能够遵循存储程序的SQL:2003语法。在理论上这意味着,如果数据库结构相同,存储程序可以在不同数据库中使用。

可支持的SQL声明
虽然MySQL不能支持存储程序,但它却可以完成很多任务,如表A所示。除此之外,MySQL的stored procedure documentation(存储过程文档)描述了可用于Oracle的PL/SQL和SQL Server的 T-SQL的很多兼容特性。我对存储过程支持的印象是,它执行比较缓慢,目的是避免任何影响大型软件开发工程的步骤。

表A

CREATE PROCEDURE
建立一个存放在MySQL数据库的表格的存储过程。

CREATE FUNCTION
建立一个用户自定义的函数,尤其是返回数据的存储过程。

ALTER PROCEDURE
更改用CREATE PROCEDURE 建立的预先指定的存储过程,其不会影响相关存储过程或存储功能。.

ALTER FUNCTION
更改用CREATE FUNCTION 建立的预先指定的存储过程,其不会影响相关存储过程或存储功能。.

DROP PROCEDURE
从MySQL的表格中删除一个或多个存储过程。

DROP FUNCTION
从MySQL的表格中删除一个或多个存储函数。

SHOW CREATE PROCEDURE
返回使用CREATE PROCEDURE 建立的预先指定的存储过程的文本。这一声明是SQL:2003规范的一个MySQL扩展。

SHOW CREATE FUNCTION
返回使用CREATE FUNCTION建立的预先指定的存储过程的文本。这一声明是SQL:2003规范的一个MySQL扩展。

SHOW PROCEDURE STATUS
返回一个预先指定的存储过程的特性,包括名称、类型、建立者、建立日期、以及更改日期。这一声明是SQL:2003规范的一个MySQL扩展。

SHOW FUNCTION STATUS
返回一个预先指定的存储函数的特性,包括名称、类型、建立者、建立日期、以及更改日期。这一声明是SQL:2003规范的一个MySQL扩展。

CALL
调用一个使用CREATE PROCEDURE建立的预先指定的存储过程。

BEGIN ... END
包含一组执行的多声明。

DECLARE
用于指定当地变量、环境、处理器,以及指针。

SET
用于更改当地和全局服务器变量的值。

SELECT ... INTO
用于存储显示变量的纵列。

OPEN
用于打开一个指针。

FETCH
使用特定指针来获得下一列。

CLOSE
用于关闭和打开指针。

IF
一个An if-then-else-end if 声明。

CASE ... WHEN
一个 case声明的结构

LOOP
一个简单的循环结构;可以使用LEAVE 语句来退出。

LEAVE
用于退出IF,CASE,LOOP,REPEAT以及WHILE 语句。

ITERATE
用于重新开始循环。

REPEAT
在结束时测试的循环。

WHILE
在开始时测试的循环。

RETURNS
返回一个存储过程的值。

MySQL 5.0支持存储过程语句。

重要的是,请记住当前的MySQL对存储过程的支持没有Oracle,SQL Server或者DB2的成熟。同样记住,具有少量的特性但却操作良好,这比具有大量特性但却错误百出的强得多,这一点更加重要。我知道这是一个比较奇怪的概念,但社区里的很多人有时候却被其它一些概念所迷惑。

分享到:
评论

相关推荐

    MySql 分页存储过程以及代码调用

    MySql 分页 存储过程 MySql 分页 存储过程 MySql 分页 存储过程

    Mysql存储过程常用语句模板

    Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三...

    mysql经典教程+mysql存储过程讲解

    mysql经典教程+mysql存储过程讲解 重点讲解Mysql的存储过程,触发器,游标的使用 对mysql不太熟的朋友可以好好学习。。。

    c++实现调mysql存储过程

    c++实现调mysql存储过程,实现存储过程的出参入参,可以支持查询多数据返回,还有存储过程的复杂数据的增删改等

    MySQL存储过程学习

    MySQL存储过程学习 MySQL存储过程 MySQL存储过程

    mysql存储过程实现分页

    mysql存储过程实现分页 mysql存储过程实现分页 mysql存储过程实现分页 mysql存储过程实现分页

    MySQL创建存储过程批量插入10万条数据

    MySQL创建存储过程批量插入10万条数据 存储过程 1、首先防止主键冲突,我们清空表。 TRUNCATE table A_student; 2、编写存储过程 delimiter ‘$’; CREATE PROCEDURE batchInsert(in args int) BEGIN declare i int ...

    \MySQL 5.0 存储过程.pdf

    \MySQL 5.0 存储过程.pdf\MySQL 5.0 存储过程.pdf\MySQL 5.0 存储过程.pdf\MySQL 5.0 存储过程.pdf\MySQL 5.0 存储过程.pdf

    MySQL存储过程经典教程

    MySQL存储过程经典教程MySQL存储过程经典教程MySQL存储过程经典教程MySQL存储过程经典教程MySQL存储过程经典教程MySQL存储过程经典教程

    MySQL存储过程 MySQL存储过程

    MySQL存储过程 MySQL存储过程 MySQL存储过程 MySQL存储过程 MySQL存储过程

    mysql存储过程之返回多个值的方法示例

    本文实例讲述了mysql存储过程之返回多个值的方法。分享给大家供大家参考,具体如下: mysql存储函数只返回一个值。要开发返回多个值的存储过程,需要使用带有INOUT或OUT参数的存储过程。咱们先来看一个orders表它的...

    mysql存储过程mysql存储过程

    mysql存储过程 mysql存储过程 mysql存储过程 mysql存储过程

    MySQL存储过程的异常处理方法

    本文实例讲述了MySQL存储过程的异常处理方法。分享给大家供大家参考。具体如下: mysql> mysql> delimiter $$ mysql> mysql> CREATE PROCEDURE myProc -> (p_first_name VARCHAR(30), -> p_last_name VARCHAR(30)...

    mysql存储过程和存储函数

    mysql存储过程,存储函数练习,里面有详细代码,供大家参考

    PHP_MySQL_存储过程_最新

    PHP_MySQL_存储过程_最新 储存过程

    mysql中文手册+mysql命令大全+mysql存储过程

    mysql中文手册.chm+mysql命令大全.chm+mysql存储过程.pdf

    mysql创建存储过程

    这是官网中mysql存储过程创建和函数的使用文档。

    MySQL5.0存储过程

    SQL语句需要先编译然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。...

    mysql 用存储过程 备份分表

    1、修改表名 2、创建新表 3、按时间条件插入数据 由于数据太大、用的改表名的方式备份分表,通过传入表名和条件字段名备份相应的表

    MYSQL分页存储过程

    MYSQL分页存储过程 非常实用的东西哦 希望大家能用上

Global site tag (gtag.js) - Google Analytics