Проблема с mysql LIMIT и PDO - PullRequest
5 голосов
/ 21 июня 2011

Попытка сделать страшную нумерацию страниц с использованием 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)

Но это не работает. Есть идеи?

1 Ответ

6 голосов
/ 21 июня 2011

Вам не нужно использовать метку для ограничения, так как они не исходят от ввода пользователя.Просто поместите ваши переменные 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);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...