首頁  >  文章  >  資料庫  >  預存程序的優點是什麼?

預存程序的優點是什麼?

WBOY
WBOY轉載
2023-09-12 19:41:021748瀏覽

預存程序的優點是什麼?

以下是預存程序的優點:

  • 由於預存程序是編譯和儲存的,因此無論何時呼叫過程,回應都很快。

  • 您可以將所有必要的 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 |
+-----------+--------+----------------+

以上是預存程序的優點是什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:tutorialspoint.com。如有侵權,請聯絡admin@php.cn刪除