Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/python-2.7/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php mysql限制和PDO存在问题_Php_Mysql_Pdo - Fatal编程技术网

Php mysql限制和PDO存在问题

Php mysql限制和PDO存在问题,php,mysql,pdo,Php,Mysql,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.`U

尝试使用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);

你认为这是PHP的问题,因为SQL代码本身可以工作吗?那么,它到底是如何不工作的呢?Alvaro-SQL代码在phpMyAdmin中运行良好。它只是不显示任何结果。有没有任何方法可以在我的db类中不更改或创建新函数的情况下执行与您相同的操作?如您所见,我在问题中发布了selectAll函数,有没有任何方法可以修改该函数以使其工作?@crembo:我在回答中发布了代码,哪个部分不清楚?