以下是存儲(chǔ)過(guò)程的優(yōu)點(diǎn):
由于存儲(chǔ)過(guò)程是編譯和存儲(chǔ)的,因此無(wú)論何時(shí)調(diào)用過(guò)程,響應(yīng)都很快。
您可以將所有必需的 SQL 語(yǔ)句分組在一個(gè)過(guò)程中并立即執(zhí)行它們。
由于過(guò)程存儲(chǔ)在數(shù)據(jù)庫(kù)服務(wù)器上這比客戶端更快。您可以使用它執(zhí)行所有復(fù)雜的查詢,這會(huì)更快。
使用過(guò)程,您可以避免重復(fù)代碼,而且通過(guò)這些您可以使用附加的 SQL 功能,例如調(diào)用存儲(chǔ)的函數(shù)。
編譯存儲(chǔ)過(guò)程后,您可以在任意數(shù)量的應(yīng)用程序中使用它。如果需要任何更改,您只需更改過(guò)程即可,而無(wú)需觸及應(yīng)用程序代碼。
您可以從 Java 調(diào)用 PL/SQL 存儲(chǔ)過(guò)程,也可以從 PL/SQL 調(diào)用 Java 存儲(chǔ)過(guò)程。
示例
假設(shè)我們創(chuàng)建了一個(gè)名為“Employees”的表,其描述如下:
+----------+--------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------+--------------+------+-----+---------+-------+ | Name | varchar(255) | YES | | NULL | | | Salary | int(11) | NO | | NULL | | | Location | varchar(255) | YES | | NULL | | +----------+--------------+------+-----+---------+-------+
登錄后復(fù)制
假設(shè)我們有一個(gè)名為 myProcedure 的過(guò)程,它將數(shù)據(jù)插入到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 //
登錄后復(fù)制
以下 JDBC 程序調(diào)用上述 Java 存儲(chǔ)過(guò)程。
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(); } }
登錄后復(fù)制
輸出
Connection established......
登錄后復(fù)制
如果您驗(yàn)證Employees表的內(nèi)容,您可以找到新添加的行,如下所示:
+-----------+--------+----------------+ | Name | Salary | Location | +-----------+--------+----------------+ | Amit | 3000 | Hyderabad | | Kalyan | 4000 | Vishakhapatnam | +-----------+--------+----------------+
登錄后復(fù)制
以上就是存儲(chǔ)過(guò)程的優(yōu)點(diǎn)是什么?的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注www.92cms.cn其它相關(guān)文章!