什么是存储过程的优点?

什么是存储过程的优点?

以下是存储过程的优点:

  • 由于存储过程是编译和存储的,每当您调用一个过程时,响应速度很快。

  • 您可以将所有所需的SQL语句分组到一个过程中,并一次性执行它们。

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

  • 使用存储过程,您可以避免重复的代码,而且还可以使用其他SQL功能,如调用存储函数。

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

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

阅读更多:MySQL 教程

示例

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

+----------+--------------+------+-----+---------+-------+
| 字段     | 类型         | Null | Key | 默认值  | 其他  |
+----------+--------------+------+-----+---------+-------+
| Name     | varchar(255) | YES  |     | NULL    |       |
| Salary   | int(11)      | NO   |     | NULL    |       |
| Location | varchar(255) | YES  |     | NULL    |       |
+----------+--------------+------+-----+---------+-------+
Mysql

假设我们有一个名为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 //
Mysql

以下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();
   }
}
Mysql

输出

Connection established......
Mysql

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

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

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程

登录

注册