mysql有存储过程吗

68次阅读
没有评论

共计 2843 个字符,预计需要花费 8 分钟才能阅读完成。

这篇文章主要介绍“mysql 有存储过程吗”,在日常操作中,相信很多人在 mysql 有存储过程吗问题上存在疑惑,丸趣 TV 小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql 有存储过程吗”的疑惑有所帮助!接下来,请跟着丸趣 TV 小编一起来学习吧!

mysql 有存储过程。存储过程是一组为了完成特定功能的 SQL 语句集合,MySQL5.0 版本以前不支持存储过程,但从 5.0 版本开始支持存储过程,这样既提高了数据库的处理速度,同时也提高了数据库编程的灵活性。存储过程可以用来转换数据、数据迁移、制作报表,它类似于编程语言,一次执行成功,就可以随时被调用,完成指定的功能操作。

本教程操作环境:windows7 系统、mysql8 版本、Dell G3 电脑。

mysql 有存储过程。

存储过程是一组为了完成特定功能的 SQL 语句集合。使用存储过程的目的是将常用或复杂的工作预先用 SQL 语句写好并用一个指定名称存储起来,这个过程经编译和优化后存储在数据库服务器中,因此称为存储过程。当以后需要数据库提供与已定义好的存储过程的功能相同的服务时,只需调用“CALL 存储过程名字”即可自动完成。

常用操作数据库的 SQL 语句在执行的时候需要先编译,然后执行。存储过程则采用另一种方式来执行 SQL 语句。

一个存储过程是一个可编程的函数,它在数据库中创建并保存,一般由 SQL 语句和一些特殊的控制结构组成。当希望在不同的应用程序或平台上执行相同的特定功能时,存储过程尤为合适。

MySQL 5.0 版本以前并不支持存储过程,这使 MySQL 在应用上大打折扣。MySQL 从 5.0 版本开始支持存储过程,既提高了数据库的处理速度,同时也提高了数据库编程的灵活性

存储过程是数据库中的一个重要功能,存储过程可以用来转换数据、数据迁移、制作报表,它类似于编程语言,一次执行成功,就可以随时被调用,完成指定的功能操作。

使用存储过程不仅可以提高数据库的访问效率,同时也可以提高数据库使用的安全性。

对于调用者来说,存储过程封装了 SQL 语句,调用者无需考虑逻辑功能的具体实现过程。只是简单调用即可,它可以被 Java 和 C# 等编程语言调用。

编写存储过程对开发者要求稍微高一些,但这并不影响存储过程的普遍使用,因为存储过程有如下优点:

1) 封装性

通常完成一个逻辑功能需要多条 SQL 语句,而且各个语句之间很可能传递参数,所以,编写逻辑功能相对来说稍微复杂些,而存储过程可以把这些 SQL 语句包含到一个独立的单元中,使外界看不到复杂的 SQL 语句,只需要简单调用即可达到目的。并且数据库专业人员可以随时对存储过程进行修改,而不会影响到调用它的应用程序源代码。

2) 可增强 SQL 语句的功能和灵活性

存储过程可以用流程控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。

3) 可减少网络流量

由于存储过程是在服务器端运行的,且执行速度快,因此当客户计算机上调用该存储过程时,网络中传送的只是该调用语句,从而可降低网络负载。

4) 高性能

当存储过程被成功编译后,就存储在数据库服务器里了,以后客户端可以直接调用,这样所有的 SQL 语句将从服务器执行,从而提高性能。但需要说明的是,存储过程不是越多越好,过多的使用存储过程反而影响系统性能。

5) 提高数据库的安全性和数据的完整性

存储过程提高安全性的一个方案就是把它作为中间组件,存储过程里可以对某些表做相关操作,然后存储过程作为接口提供给外部程序。这样,外部程序无法直接操作数据库表,只能通过存储过程来操作对应的表,因此在一定程度上,安全性是可以得到提高的。

6) 使数据独立

数据的独立可以达到解耦的效果,也就是说,程序可以调用存储过程,来替代执行多条的 SQL 语句。这种情况下,存储过程把数据同用户隔离开来,优点就是当数据表的结构改变时,调用表不用修改程序,只需要数据库管理者重新编写存储过程即可。

MySQL 存储过程实例

我们将逐步向您展示如何使用 CREATE PROCEDURE 开发第一个 MySQL 存储过程。此外,我们将向您展示如何从 SQL 语句调用存储过程。

编写第一个 MySQL 存储过程

我们将开发一个简单的存储过程,以 GetAllProducts()   帮助您熟悉语法。GetAllProducts()   存储过程选择所有产品从 products 表。

启动 mysql 客户端工具并键入以下命令:

 DELIMITER //
 CREATE PROCEDURE GetAllProducts()
 BEGIN
 SELECT productCode, productName FROM products;
 END //
 DELIMITER ;

执行命令:

mysql  DELIMITER //
mysql  CREATE PROCEDURE GetAllProducts()
-  BEGIN
-  SELECT productCode, productName FROM products;
-  END //
Query OK, 0 rows affected (0.02 sec)
mysql  DELIMITER ;

让我们更详细地检查存储过程:

第一个命令是 DELIMITER //,与存储过程语法无关。DELIMITER 语句将标准分隔符(分号(;)更改为另一个分号)。在这种情况下,分隔符从分号(;)更改为双斜线 //。为什么我们要更改分隔符?因为我们希望将存储过程作为一个整体传递给服务器,而不是让 mysql 工具一次解释每个语句。在 END 关键字之后,我们使用分隔符 //   来指示存储过程的结束。最后一个命令(DELIMITER;)将分隔符更改回分号(;)。

我们使用 CREATE PROCEDURE   语句来创建一个新的存储过程。我们在 CREATE PROCEDURE   语句后指定存储过程的名称。在这种情况下,存储过程的名称是 GetAllProducts。我们将括号放在存储过程的名称之后。

BEGIN 和之间的部分  END   称为存储过程的主体。您将声明性 SQL 语句放在正文中以处理业务逻辑。在这个存储过程中,我们使用一个简单的 SELECT 语句来查询 products 表中的数据。

查看存储过程

我们可以使用如下命令查看指定的数据库中有哪些存储过程:

 select name from mysql.proc where db= mysqldemo

运行结果:

调用存储过程

要调用存储过程,请使用以下 SQL 命令:

CALL stored_procedure_name();

您使用 CALL 语句调用存储过程,例如,要调用 GetAllProducts() 存储过程,请使用以下语句:

CALL GetAllProducts();

如果执行上述语句,您将获得 products 表中的所有产品。

到此,关于“mysql 有存储过程吗”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注丸趣 TV 网站,丸趣 TV 小编会继续努力为大家带来更多实用的文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计2843字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)