我正面临着下一个问题:
我制作了如下存储过程:
CREATE PROCEDURE verify_user_connection
@username nvarchar(50),
@pass nvarchar(50)
AS
BEGIN
SELECT users.username, users.pass
FROM dbo.users
WHERE users.username = '@username'
AND users.pass = '@pass'
RETURN '@username'
END
从PHP代码我称他为:
<?php
/* Handle form buttons. */
if (isset($_POST['login'])) {
if (!empty($_POST['username']) || !empty($_POST['pass'])) {
$username = $_POST['username'];
$password = $_POST['pass'];
$sql = "{ CALL dbo.verify_user_connection (@username = ?, @pass = ?) }";
$param = array($username, $password);
$result = sqlsrv_query($conn, $sql, $param);
$row = sqlsrv_fetch_object($result);
echo $row;
if (!$row) {
die(print_r(sqlsrv_errors()));
}
else {
echo "record found";
}
}
else {
echo "something went wrong";
}
}
?>
我是微软的SQLSRV驱动程序中的新手,我知道我的语法在这里不准确 有人可以解决我的问题并向我解释我做错了什么?
提前致谢
答案 0 :(得分:1)
这不会有太大的帮助,但是我发现使用SQL Server和SP的最可靠的方法是使用PHP ADODB(http://adodb.sourceforge.net/#download)来连接和调用proc。
在使用SQL服务器时,我总是发现内置的sql server功能最多。
如果您仍在努力,我很乐意通过电子邮件向您提供更多信息。