存储过程的优势是什么?
以下是使用存储过程的优势
由于存储过程经过编译和存储,因此每当您调用过程时,响应都很快。
您可以将所有必需的 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:///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 | +-----------+--------+----------------+
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP