似乎没有问题,我不明白为什么不返回数据
这是我的存储过程:
DELIMITER $$
DROP PROCEDURE IF EXISTS `test`.`get_products`$$
CREATE PROCEDURE `test`.`get_products`
(
OUT out_productName VARCHAR(255)
)
BEGIN
SELECT productName INTO out_productName FROM products;
END $$
DELIMITER ;
我是这么称呼它的
$rs = mysql_query( 'CALL get_products(@f)' );
$rs = mysql_query( 'SELECT @f' );
while($row = mysql_fetch_assoc($rs))
{
print_r($row);
}
这并不能完全回答你的问题,但一个解决办法是不使用输出参数
DELIMITER $$
DROP PROCEDURE IF EXISTS `test`.`get_products`$$
CREATE PROCEDURE `test`.`get_products`
(
)
BEGIN
SELECT productName INTO @f FROM products;
END $$
DELIMITER ;
mysql_query( 'set @f = 0;' );
$rs = mysql_query( 'CALL get_products()' );
$rs = mysql_query( 'SELECT @f' );
while($row = mysql_fetch_assoc($rs))
{
print_r($row);
}
@f将由数据库维护,并且可以在sql会话中访问,如果我没记错的话
还可以在从存储过程获取结果的同时返回一些东西,您还需要使用
$rs->close();
$connection->next_result();
connection是你命名的连接字符串
尝试:
DELIMITER $$
DROP PROCEDURE IF EXISTS test.get_products;
CREATE PROCEDURE test.get_products()
BEGIN
SELECT productName FROM products;
END $$
DELIMITER ;
并命名为:
$rs = mysql_query( 'CALL test.get_products()' );
while($row = mysql_fetch_assoc($rs))
{
print_r($row);
}