首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PDO不获取任何结果

PDO不获取任何结果
EN

Stack Overflow用户
提问于 2016-04-14 21:10:20
回答 1查看 48关注 0票数 0

我在index.php file.Now中直接使用了PDO查询,我想创建一个单独的文件来存储函数。我创建了一个函数,但当我调用函数时,只返回"0“。旧版本可以工作:

代码语言:javascript
复制
$abfrage11 = "SELECT COUNT(e.event_id) as numgoals
FROM event e 
WHERE (e.match_id = '$row1->match_id' AND e.team_id = '$row1->team_a_id' AND e.eventtype IN ('soc_G','soc_PG') ) OR
      (e.match_id = '$row1->match_id' AND e.team_id = '$row1->team_b_id' AND e.eventtype = 'soc_OG' )";
$ergebnis11 = $dbh->query($abfrage11);
$row11 = $ergebnis11->fetch(PDO::FETCH_OBJ);

新版本中的BUt不:

单独文件"storage.php":

代码语言:javascript
复制
class StorageAccess
{
    /** @var  PDO */
    public $db;

    /**
     * @param $db
     */
    public function __construct($db)
    {
        $this->db = $db;

    }
public function getAbfrage11()
    {
        $query = "SELECT COUNT(e.event_id) as numgoals
                    FROM event e 
                    WHERE (e.match_id = :mId AND e.team_id = :tmA AND e.eventtype IN ('soc_G','soc_PG') ) OR
                          (e.match_id = :mId2 AND e.team_id = :tmB AND e.eventtype = 'soc_OG' )";
        $statement = $this->db->prepare($query);
        $statement->execute([
            ':mId' => $row1->match_id,
            ':mId2' => $row1->match_id,
            ':tmA' => $row1->team_a_id,
            ':tmB' => $row1->team_b_id,
        ]);
        return $statement->fetchObject();
    }
}

在index.php中调用:

代码语言:javascript
复制
require_once("dblogin.php");
require_once("Storage.php");

$dbFactory = new RepositoriesFactory();
$dbh = $dbFactory->getDataBaseInstance('admgsa_gsa');
$storage_access = new StorageAccess($dbh);

$row11 = $storage_access->getAbfrage11();
echo "<span class='live-monitor-8' style=\"$goalscbgcolor\">$row11->numgoals</span>";

尝试搜索解决方案,但什么也找不到。提前感谢您的帮助。

EN

回答 1

Stack Overflow用户

发布于 2016-04-14 22:31:18

知道问题出在哪里了。我没有指定输入参数:

代码语言:javascript
复制
public function getAbfrage11($row1)
    {
        $query = "SELECT COUNT(e.event_id) as numgoals
                    FROM event e 
                    WHERE (e.match_id = :mId AND e.team_id = :tmA AND e.eventtype IN ('soc_G','soc_PG') ) OR
                          (e.match_id = :mId2 AND e.team_id = :tmB AND e.eventtype = 'soc_OG' )";
        $statement = $this->db->prepare($query);
        $statement->execute([
            ':mId' => $row1->match_id,
            ':mId2' => $row1->match_id,
            ':tmA' => $row1->team_a_id,
            ':tmB' => $row1->team_b_id,
        ]);
        return $statement->fetchObject();
    }

这解决了我的问题。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36624159

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档