以下是存儲過程的優點:
由于存儲過程是編譯和存儲的,因此無論何時調用過程,響應都很快。
您可以將所有必需的 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 | +-----------+--------+----------------+
登錄后復制
以上就是存儲過程的優點是什么?的詳細內容,更多請關注www.92cms.cn其它相關文章!






