从 PHP PDO 调用 SQL 存储过程

Posted

技术标签:

【中文标题】从 PHP PDO 调用 SQL 存储过程【英文标题】:Call SQL Stored Procedure from PHP PDO 【发布时间】:2019-05-11 08:52:48 【问题描述】:

我需要调用一个存储过程来将数据插入到 sql 并返回一个带有输出参数的值

喜欢

CREATE PROCEDURE InsertInfo
   @userid VARCHAR(100),
   @login_time DATETIME,
   @IsSuccuess BIT,
   @loginid INT OUTPUT
   AS
   BEGIN
      INSERT INTO Audit_LoginLogoutAttempt(UserID,Login_Time, IsSuccuess, DateCreated) VALUES (@userid,@login_time,@IsSuccuess, GETDATE())
      SET @loginid = @@IDENTITY
   END
   GO

如何使用 php 发送输入和输出参数

  $stmt = $conn->prepare("CALL InsertInfo(?, ?, ?, ?)");
  $stmt->bindParam(1, $UserID);
  $stmt->bindParam(2, $LoggedInDateTime);
  $stmt->bindParam(3, $IsSuccuess);
  $stmt->bindParam(4, $get_id, PDO::PARAM_INT, 32);
  $stmt->execute();
  echo $get_id;

我尝试过这样,但我没有从 $get_id 获得所需的价值

【问题讨论】:

【参考方案1】:

您应该将bind 您的参数作为 OUTPUT 参数。如果您的存储过程中有输出参数并且存储过程返回记录集,则需要获取所有记录集以获取输出值。

<?php

# Statement
$stmt = $conn->prepare("CALL InsertInfo(?, ?, ?, ?)");
$stmt->bindParam(1, $UserID);
$stmt->bindParam(2, $LoggedInDateTime);
$stmt->bindParam(3, $IsSuccuess);
$stmt->bindParam(4, $get_id, PDO::PARAM_INT|PDO::PARAM_INPUT_OUTPUT, PDO::SQLSRV_PARAM_OUT_DEFAULT_SIZE);
$stmt->execute();

# Fetch results. Include this if your procedure returns resultsets (usually from SELECT statements):
#do 
#   while ($row = $stmt->fetch()) 
#       // 
#   
# while ($stmt->nextRowset());


# Get OUTPUT parameter value
echo $get_id;

?>

我通常将SET NOCOUNT ON 作为存储过程的第一行。这可以防止 SQL Server 将受影响的行数作为结果集的一部分传递。

CREATE PROCEDURE InsertInfo
   @userid VARCHAR(100),
   @login_time DATETIME,
   @IsSuccuess BIT,
   @loginid INT OUTPUT
AS
BEGIN
    SET NOCOUNT ON
    INSERT INTO Audit_LoginLogoutAttempt(UserID,Login_Time, IsSuccuess, DateCreated) VALUES (@userid,@login_time,@IsSuccuess, GETDATE())
    SET @loginid = @@IDENTITY
END

【讨论】:

以上是关于从 PHP PDO 调用 SQL 存储过程的主要内容,如果未能解决你的问题,请参考以下文章

使用 PHP PDO 将参数传递给 SQL Server 存储过程

使用 PDO 从 PHP 调用存储过程到使用 INPUT 参数的 MYSQL Server

使用 PDO 调用带有 Out 参数的存储过程

PHP MySQL PDO 存储过程和 INOUT 参数

使用 php PDO 调用多个存储过程

使用 PHP PDO 调用 MySQL 存储过程 [重复]