Heim >Backend-Entwicklung >PHP-Tutorial >Warum funktioniert LIMIT nicht mit vorbereiteten Anweisungen in MySQL?

Warum funktioniert LIMIT nicht mit vorbereiteten Anweisungen in MySQL?

Barbara Streisand
Barbara StreisandOriginal
2024-11-26 19:27:10860Durchsuche

Why Doesn't LIMIT Work with Prepared Statements in MySQL?

LIMIT-Schlüsselwort mit vorbereiteten Anweisungen in MySQL

Diese Frage befasst sich mit einem Problem, bei dem die LIMIT-Klausel bei der Verwendung vorbereiteter Anweisungen nicht wie erwartet funktioniert mit der PDO-Bibliothek in MySQL.

Im bereitgestellten Code snippet:

<pre class="brush:php;toolbar:false">
$comments = $db->prepare($query); 
/* where $db is the PDO object */ 
$comments->execute(array($post, $min, $max)); 

Die Parameter $min und $max werden von der Methode PDOStatement::execute als Strings behandelt. Folglich lautet die endgültige SQL-Anweisung:

LIMIT '0', '10'

was zu einem Syntaxfehler führt, da MySQL numerische Werte für die LIMIT-Klausel erfordert.

Mögliche Lösungen:

Um dieses Problem zu beheben, ziehen Sie die folgenden Optionen in Betracht:

  • Binden Parameter manuell:

    • Binden Sie jeden Parameter mit bindParam an einen geeigneten Typ.
    • Zum Beispiel: $comments->bindParam(2, $min, PDO::PARAM_INT );
  • String verwenden Interpolation:

    • Betten Sie die $min- und $max-Werte mit sprintf direkt in die Abfragezeichenfolge ein.
    • Beispiel:

      $query = sprintf('SELECT id, content, date
      FROM comment
      WHERE post = ?
      ORDER BY date DESC
      LIMIT %d, %d', $min, $max);
  • Emuliert deaktivieren Bereitet vor:

    • Setzen Sie das Attribut PDO::ATTR_EMULATE_PREPARES auf FALSE, um zu verhindern, dass MySQL numerische Argumente in Anführungszeichen setzt.
    • Beispiel: $db->setAttribute(PDO::ATTR_EMULATE_PREPARES , FALSE);

Hinweis:
Mit diesen Methoden können Sie die LIMIT-Klausel mit vorbereiteten Anweisungen korrekt verwenden.

Das obige ist der detaillierte Inhalt vonWarum funktioniert LIMIT nicht mit vorbereiteten Anweisungen in MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn