[英]Call SQL Stored Procedure from PHP PDO
我需要调用一个存储过程将数据插入 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 获得所需的价值
您应该将参数绑定为 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
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.