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)
广告