MySQL 存储过程的 in 和 out 参数示例及 PHP、PB 的调用方法

2025-01-15 04:38:27   小编

MySQL 存储过程的 in 和 out 参数示例及 PHP、PB 的调用方法

在数据库开发中,MySQL 存储过程的 in 和 out 参数发挥着重要作用,同时了解如何在 PHP 和 PowerBuilder(PB)中调用它们,能极大提升开发效率。

首先来看 MySQL 存储过程中 in 和 out 参数的示例。In 参数用于向存储过程传递值。例如,创建一个存储过程来根据员工编号查询员工姓名:

DELIMITER //
CREATE PROCEDURE GetEmployeeName(IN emp_id INT)
BEGIN
    SELECT emp_name FROM employees WHERE emp_id = emp_id;
END //
DELIMITER ;

在这个过程中,emp_id 就是 in 参数,调用时传入具体的员工编号,就能获取相应员工的姓名。

Out 参数则用于从存储过程返回值。比如,创建一个存储过程计算两个数的和并返回结果:

DELIMITER //
CREATE PROCEDURE SumNumbers(IN num1 INT, IN num2 INT, OUT sum_result INT)
BEGIN
    SET sum_result = num1 + num2;
END //
DELIMITER ;

这里 sum_result 就是 out 参数,调用该存储过程后,就能获取计算出的两数之和。

接下来是在 PHP 中调用这些存储过程。使用 mysqli 扩展为例:

<?php
$mysqli = new mysqli("localhost", "username", "password", "database_name");
if ($mysqli->connect_error) {
    die("连接失败: ". $mysqli->connect_error);
}

// 调用带 in 参数的存储过程
$stmt = $mysqli->prepare("CALL GetEmployeeName(?)");
$emp_id = 1;
$stmt->bind_param("i", $emp_id);
$stmt->execute();
$stmt->store_result();
$stmt->bind_result($emp_name);
while ($stmt->fetch()) {
    echo "员工姓名: ". $emp_name;
}
$stmt->close();

// 调用带 out 参数的存储过程
$stmt = $mysqli->prepare("CALL SumNumbers(?,?,?)");
$num1 = 5;
$num2 = 3;
$sum_result = 0;
$stmt->bind_param("iiout", $num1, $num2, $sum_result);
$stmt->execute();
echo "两数之和: ". $sum_result;
$stmt->close();

$mysqli->close();
?>

在 PowerBuilder 中调用存储过程,也有其特定的语法。通过嵌入式 SQL 语句来实现,例如:

// 调用带 in 参数的存储过程
DECLARE GetEmployeeNameProc PROCEDURE FOR GetEmployeeName (:ls_emp_id);
EXECUTE GetEmployeeNameProc;
FETCH GetEmployeeNameProc INTO :ls_emp_name;
CLOSE GetEmployeeNameProc;

// 调用带 out 参数的存储过程
DECLARE SumNumbersProc PROCEDURE FOR SumNumbers (:li_num1, :li_num2, :li_sum_result);
EXECUTE SumNumbersProc;
CLOSE SumNumbersProc;

通过上述示例,我们清晰地看到了 MySQL 存储过程中 in 和 out 参数的用法,以及在 PHP 和 PB 中如何有效调用,这为开发人员在数据库相关项目中提供了有力的技术支持。

TAGS: MySQL存储过程 in和out参数 PHP调用 PB调用

欢迎使用万千站长工具!

Welcome to www.zzTool.com