美文网首页MySQL
29-存储过程和函数小结

29-存储过程和函数小结

作者: 紫荆秋雪_文 | 来源:发表于2022-09-01 11:00 被阅读0次

一、查看

  • 方式一:使用SHOW CREATE语句查看存储过程和函数的创建信息
SHOW CREATE {PROCEDURE | FUNCTION} 存储过程名或函数名
eg:
SHOW CREATE FUNCTION test_db.CountProc \G
  • 方式二: 使用SHOW STATUS语句查看存储过程和函数的状态信息
SHOW {PROCEDURE | FUNCTION} STATUS [LIKE 'pattern']
  • 方式三: 从information_schema.Routines表中查看存储过程和函数的信息
SELECT * FROM information_schema.Routines 
WHERE ROUTINE_NAME='存储过程或函数的名' [AND ROUTINE_TYPE = {'PROCEDURE|FUNCTION'}];
SELECT * FROM information_schema.Routines 
WHERE ROUTINE_NAME='count_by_id' AND ROUTINE_TYPE = 'FUNCTION' \G

二、修改

修改存储过程或函数,不影响存储过程或函数功能,只是修改相关特性。使用ALTER语句实现其中,characteristic指定存储过程或函数的特性,其取值信息与创建存储过程、函数时的取值信息略有不同。

ALTER {PROCEDURE | FUNCTION} 存储过程或函数的名 [characteristic ...]
{ CONTAINS SQL | NO SQL | READS SQL DATA 
| MODIFIES SQL DATA } | SQL SECURITY { DEFINER | INVOKER } 
| COMMENT 'string'
  • CONTAINS SQL :表示子程序包含SQL语句,但不包含读或写数据的语句。
  • NO SQL:表示子程序中不包含SQL语句。
  • READS SQL DATA:表示子程序中包含读数据的语句。
  • MODIFIES SQL DATA:表示子程序中包含写数据的语句。
  • SQL SECURITY { DEFINER | INVOKER }:指明谁有权限来执行。
  • DEFINER:表示只有定义者自己才能够执行。
  • INVOKER:表示调用者可以执行。
  • COMMENT 'string':表示注释信息。

1、修改存储过程CountProc的定义。将读写权限改为MODIFIES SQL DATA,并指明调用者可以执行,代码如

ALTER PROCEDURE CountProc 
MODIFIES SQL DATA 
SQL SECURITY INVOKER ;
  • 查询修改后的信息
SELECT specific_name,sql_data_access,security_type 
FROM information_schema.`ROUTINES` 
WHERE routine_name = 'CountProc' AND routine_type = 'PROCEDURE';
  • 结果显示,存储过程修改成功。从查询的结果可以看出,访问数据的权限(SQL_DATA_ ACCESS)已经变
    成MODIFIES SQL DATA,安全类型(SECURITY_TYPE)已经变成INVOKER

2、修改存储函数CountProc的定义。将读写权限改为READS SQL DATA,并加上注释信息“FIND NAME”

ALTER FUNCTION CountProc 
READS SQL DATA 
COMMENT 'FIND NAME' ;
  • 存储函数修改成功。从查询的结果可以看出,访问数据的权限(SQL_DATA_ACCESS)已经变成READS SQL DATA,函数注释(ROUTINE_COMMENT)已经变成FIND NAME

三、删除

  • 删除存储过程和函数,可以使用DROP语句,其语法结构如下
DROP {PROCEDURE | FUNCTION} [IF EXISTS] 存储过程或函数的名
  • IF EXISTS:如果程序或函数不存储,它可以防止发生错误,产生一个用SHOW WARNINGS查看的警告
DROP PROCEDURE CountProc;
DROP FUNCTION CountProc;

四、优点

  • 1、存储过程可以一次编译多次使用。存储过程只在创建时进行编译,之后的使用都不需要重新编译,
    这就提升了 SQL 的执行效率。
  • 2、可以减少开发工作量。将代码 封装 成模块,实际上是编程的核心思想之一,这样可以把复杂的问题
    拆解成不同的模块,然后模块之间可以 重复使用 ,在减少开发工作量的同时,还能保证代码的结构清
    晰。
  • 3、存储过程的安全性强。我们在设定存储过程的时候可以 设置对用户的使用权限 ,这样就和视图一样具
    有较强的安全性。
  • 4、可以减少网络传输量。因为代码封装到存储过程中,每次使用只需要调用存储过程即可,这样就减
    少了网络传输量。
  • 5、良好的封装性。在进行相对复杂的数据库操作时,原本需要使用一条一条的 SQL 语句,可能要连接
    多次数据库才能完成的操作,现在变成了一次存储过程,只需要 连接一次即可 。

五、缺点

  • 1、可移植性差。存储过程不能跨数据库移植,比如在 MySQL、Oracle 和 SQL Server 里编写的存储过
    程,在换成其他数据库时都需要重新编写。
  • 2、调试困难。只有少数 DBMS 支持存储过程的调试。对于复杂的存储过程来说,开发和维护都不容
    易。虽然也有一些第三方工具可以对存储过程进行调试,但要收费。
  • 3、存储过程的版本管理很困难。比如数据表索引发生变化了,可能会导致存储过程失效。我们在开发
    软件的时候往往需要进行版本管理,但是存储过程本身没有版本控制,版本迭代更新的时候很麻烦。
  • 4、它不适合高并发的场景。高并发的场景需要减少数据库的压力,有时数据库会采用分库分表的方
    式,而且对可扩展性要求很高,在这种情况下,存储过程会变得难以维护, 增加数据库的压力 ,显然就
    不适用了

相关文章

  • 29-存储过程和函数小结

    一、查看 方式一:使用SHOW CREATE语句查看存储过程和函数的创建信息 方式二: 使用SHOW STATUS...

  • 深入浅出MySQL之开发篇(二)

    继续深入了解MySQL的高级特性。 1.存储过程和函数 什么是存储过程和函数 存储过程和函数是事先经过编译并存储在...

  • MySQL 视图和存储程序

    MySQL 视图和存储程序 存储程序:存储函数、存储过程、触发器和事件的总称。 存储例程:存储函数+存储过程。 触...

  • PL/SQL之存储过程

    存储过程、存储函数和触发器 存储过程和存储函数定义:指存储在数据库中供所有用户程序调用的子程序叫存储过程或存储函数...

  • Oracle之存储过程与存储函数

    存储过程和存储函数指存储在数据库中供所有用户程序调用的子程序叫存储过程或者存储函数;存储过程和存储函数相同点:完成...

  • mysql基础(三)

    存储过程和函数 存储过程和函数的引入 存储过程和函数是在数据库中定义一些 SQL 语句的集合,然后直接调用这些存储...

  • mysql的存储过程及其使用场景,和存储函数的区别

    简单了解什么是存储过程,以及存储过程的使用场景,和存储函数、触发气的区别: 存储过程,存储函数,触发器和事件是自从...

  • 存储过程和函数

    存储过程 类似Java中的“方法”好处:1、 代码复用2、 简化操作 存储过程:一组预先编译的SQL语句的集合...

  • 存储过程和函数

    存储结构一般用来插入更新数据函数用来查询 一、 创建存储结构 参数别表填写规则IN 名字 类型OUT 名字 类型 ...

  • 存储过程和函数

    存储过程和函数:类似于java中的方法好处:1、提高代码的重用性2、简化操作 存储过程 含义: 一组预先编译好的S...

网友评论

    本文标题:29-存储过程和函数小结

    本文链接:https://www.haomeiwen.com/subject/brzjnrtx.html