我正在尝试使用 PDO 从存储过程中提取数据,但我很难确定这一点。在过去的几天里,我四处寻找,似乎无法找到解决我问题的直接方法。
这就是我创建过程的方式:
DELIMITER $$
CREATE PROCEDURE sp_searchArticles(
IN tagList VARCHAR(255),
IN lastArticle INT(10),
OUT data INT(10))
BEGIN
CREATE TEMPORARY TABLE at_results (
id INTEGER(10) NOT NULL AUTO_INCREMENT PRIMARY KEY,
article_id INTEGER(10) NOT NULL,
datetime DATETIME NOT NULL,
common_tags INTEGER NOT NULL)
SELECT at.article_id, art.datetime, Count(at.article_id) AS common_tags
FROM article_tags AS at
INNER JOIN articles AS art ON at.article_id = art.article_id
WHERE at.tag_id IN (tagList)
GROUP BY at.article_id
ORDER BY common_tags DESC, art.datetime DESC;
CREATE TEMPORARY TABLE at_article
SELECT id
FROM at_results
WHERE article_id = lastArticle;
SELECT article_id
INTO data
FROM at_results, at_article
WHERE at_results.id > at_article.id;
END $$
DELIMITER ;
然后我使用 PDO 调用 SP:
$sql = "CALL sp_searchArticles(:tag_list, :last_article, @data)";
$tag_sth = $this->db->prepare($sql);
$tag_sth->bindParam(':tag_list', $tag_list);
$tag_sth->bindParam(':last_article', $last_article);
$tag_sth->execute();
$data = $this->db->query("select @data")->fetch(PDO::FETCH_ASSOC);
但它返回“#1436 - 线程堆栈溢出:”
我尝试在不使用 @data out 变量的情况下调用存储过程,但出现 HY000 错误。我原本不希望这个调用是一个存储过程,但是 PDO 似乎不喜欢我在一次执行中有多个语句的脸。此外,我似乎无法通过 phpmyadmin 使用静态参数正确调用该过程。然而,sql 语句在过程之外可以完美地工作。
我不是最精通 PDO 和 mySQL,但我已经阅读了很多关于 phpmyadmin、PDO 和 PHP 中与存储过程有关的错误。任何帮助将不胜感激。