登录
首页 >  数据库 >  MySQL

存储过程的优点是什么?

来源:tutorialspoint

时间:2023-09-06 16:44:41 390浏览 收藏

“纵有疾风来,人生不言弃”,这句话送给正在学习数据库的朋友们,也希望在阅读本文《存储过程的优点是什么?》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新数据库相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

以下是存储过程的优点:

  • 由于存储过程是编译和存储的,因此无论何时调用过程,响应都很快。

  • 您可以将所有必需的 SQL 语句分组在一个过程中并立即执行它们。

  • 由于过程存储在数据库服务器上这比客户端更快。您可以使用它执行所有复杂的查询,这会更快。

  • 使用过程,您可以避免重复代码,而且通过这些您可以使用附加的 SQL 功能,例如调用存储的函数。

  • 编译存储过程后,您可以在任意数量的应用程序中使用它。如果需要任何更改,您只需更改过程即可,而无需触及应用程序代码。

  • 您可以从 Java 调用 PL/SQL 存储过程,也可以从 PL/SQL 调用 Java 存储过程。

示例

假设我们创建了一个名为“Employees”的表,其描述如下:

+----------+--------------+------+-----+---------+-------+
| Field    | Type         | Null | Key | Default | Extra |
+----------+--------------+------+-----+---------+-------+
| Name     | varchar(255) | YES  |     | NULL    |       |
| Salary   | int(11)      | NO   |     | NULL    |       |
| Location | varchar(255) | YES  |     | NULL    |       |
+----------+--------------+------+-----+---------+-------+

假设我们有一个名为 myProcedure 的过程,它将数据插入到Employees 表中,如下所示:

Create procedure myProcedure (IN name VARCHAR(30), IN sal INT, IN loc VARCHAR(45))
   -> BEGIN
   -> INSERT INTO Employees(Name, Salary, Location) VALUES (name, sal, loc);
   -> END //

以下 JDBC 程序调用上述 Java 存储过程。

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class Example {
   public static void main(String args[]) throws SQLException {
      //Registering the Driver
      DriverManager.registerDriver(new com.mysql.jdbc.Driver());
      //Getting the connection
      String mysqlUrl = "jdbc:mysql://localhost/testdb";
      Connection con = DriverManager.getConnection(mysqlUrl, "root", "password");
      System.out.println("Connection established......");
      //Preparing a CallableStatement
      CallableStatement cstmt = con.prepareCall("{call myProcedure(?, ?, ?)}");
      cstmt.setString(1, "Amit");
      cstmt.setInt(2, 3000);
      cstmt.setString(3, "Hyderabad");
      cstmt.execute();
      cstmt.setString(1, "Kalyan");
      cstmt.setInt(2, 4000);
      cstmt.setString(3, "Vishakhapatnam");
      cstmt.execute();
   }
}

输出

Connection established......

如果您验证Employees表的内容,您可以找到新添加的行,如下所示:

+-----------+--------+----------------+
| Name      | Salary | Location       |
+-----------+--------+----------------+
| Amit      | 3000   | Hyderabad      |
| Kalyan    | 4000   | Vishakhapatnam |
+-----------+--------+----------------+

到这里,我们也就讲完了《存储过程的优点是什么?》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

声明:本文转载于:tutorialspoint 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>