微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – mysql LIMIT和PDO的问题

尝试使用PDO进行可怕的分页,但我找不到符合我情况的答案:

    $pageVar = 10;
    $startRowLimit = ($page * $pageVar) - $pageVar; // returns correct value 

$articlesQuery = "SELECT 
`ID`,`Title`,`Text`,`Poster`,`Date`,
( SELECT `ID` FROM users WHERE article.`Poster` = users.`Username` )
FROM article WHERE `Visible` = 1 ORDER BY `Date` DESC LIMIT ? , ? ";

$articles = $MysqLi->selectAll($articlesQuery, array($startRowLimit, $pageVar));

这是selectAll函数

        public function selectAll($query, $params){

        $this->sql = $this->dbh->prepare($query);
        $this->sql->execute($params);
        $result = $this->sql->fetchAll(PDO::FETCH_ASSOC);

        return $result;

    }

我怎样才能使它工作?我试过了

array((int) $startRowLimit, (int) $pageVar)

但这不起作用.任何的想法?

解决方法:

您不需要使用标记作为限制,因为它们不是来自用户输入.只需将int变量放入查询中即可

DESC LIMIT {$offset} , {$var}

无论如何,正确的语法是:

$sql = "SELECT * [...] LIMIT :start, :results";
$stmt = $dbh->prepare($sql);
$stmt->bindParam(':start', $_GET['start'], PDO::ParaM_INT);
$stmt->bindParam(':results', $_GET['results'], PDO::ParaM_INT);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐