
以下是存储过程的优点:
由于存储过程是编译和存储的,因此无论何时调用过程,响应都很快。
您可以将所有必需的 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 |+-----------+--------+----------------+
以上就是存储过程的优点是什么?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/104295.html
微信扫一扫
支付宝扫一扫