dsunj08246 2017-12-27 20:03
浏览 103
已采纳

如何在PHP中使用PDO获取MS SQL存储过程返回值?

Simple example

CREATE PROCEDURE [dbo].[InsertLoginInPHP]
    @login as nvarchar(50), @password as nvarchar(50), @resultOK as int, @resultnot as int

AS
BEGIN
    SET @resultOK = 10
    SET @resultnot = 1

    IF EXISTS (SELECT * FROM Users WHERE Login = @login)
        BEGIN
            SELECT @resultnot as return // 1
        END
    ELSE
        BEGIN
            INSERT INTO Users (Login,Password) VALUES(@login,@password)
            SELECT @resultOK as return // 10
        END
END

and In php

$query = ("EXECUTE InsertLogin :login, :password");
$query_stored = $conn->prepare($query);
$query_stored->bindvalue(':login', $login);
$query_stored->bindvalue(':password', $password);   
$query_stored->execute();

How can I get return value ( @resultnot or @resultOK ) in php? And How can I get and use return value in JSON? Like this

json_encode(array('status'=>'Ok','return'=>$query_sotored[resultOK])));
  • 写回答

1条回答 默认 最新

  • douzou8074 2017-12-27 20:52
    关注

    You need to fetch a row from the statement, then access the column from the array this returns.

    $query = ("EXECUTE InsertLogin :login, :password");
    $query_stored = $conn->prepare($query);
    $query_stored->bindvalue(':login', $login);
    $query_stored->bindvalue(':password', $password);   
    $query_stored->execute();
    $row = $query_stored->fetch(PDO::FETCH_ASSOC);
    echo json_encode(array('status'=>'Ok','return'=>$row['return'])))
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题