JDBC 中的存储过程是什么?


存储过程是子程序,存储在 SQL 目录中的 SQL 语句片段。所有能够访问关系数据库(Java、Python、PHP 等)的应用程序都可以访问存储过程。

存储过程包含输入和输出参数或两者兼而有之。如果使用 SELECT 语句,它们可能会返回结果集。存储过程可以返回多个结果集。

创建存储过程

假设我们在 MySQL 数据库中创建了一个名为 Employee 的表,如下所示

String createTable = "CREATE TABLE Employee("
   + "Name VARCHAR(255), "
   + "Salary INT NOT NULL, "
   + "Location VARCHAR(255))";

以下是一个 MySQL 存储过程的示例。在这里,我们将一列插入到 **Employee** 表中,并从用户处获取值。(通过输入参数)

mysql> DELIMITER // ;
mysql> Create procedure myProcedure (IN name VARCHAR(30), IN sal INT, IN locVARCHAR(45))
   -> BEGIN
   -> INSERT INTO Employee(Name, Salary, Location) VALUES (name, sal, loc);
   -> END //
Query OK, 0 rows affected (0.13 sec)

调用存储过程

以下语句调用上面创建的存储过程。

CALL myProcedure ('Raman', 35000, 'Bangalore')//

如果检索表的內容,您可以观察到新插入的行,如下所示

mysql> select * from employee;
+---------+--------+----------------+
| Name    | Salary | Location       |
+---------+--------+----------------+
|| Raman  | 35000  | Bangalore      |
+---------+--------+----------------+
1 rows in set (0.00 sec)

更新于: 2019-07-30

291 次浏览

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告