阅读 112

存储过程的优点是什么?

以下是存储过程的优点:

  • 由于存储过程是编译和存储的,因此无论何时调用过程,响应都很快。

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


文章分类
代码人生
文章标签
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐