Passer des paramètres de tableau avec la clause LIMIT dans PDO
En PHP, la classe PDOStatement fournit un moyen d'exécuter des requêtes SQL avec des valeurs paramétrées. Cependant, lors de l'utilisation de la clause LIMIT, la liaison des paramètres à l'aide de la méthode bindParam() ne fonctionne pas.
Pour résoudre ce problème, envisagez la solution suivante :
<code class="php">$sql = "SELECT * FROM table WHERE id LIKE CONCAT('%', :id, '%') LIMIT :offset, :limit"; $stmt = $pdo->prepare($sql); // Turn off PDO emulation of prepared statements for MySQL $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); $array = [':id' => 5]; // Bind the LIMIT parameters $stmt->bindParam(':offset', $limit1, PDO::PARAM_INT); $stmt->bindParam(':limit', $limit2, PDO::PARAM_INT); // Execute the query $stmt->execute($array); $results = $stmt->fetchAll();</code>
En désactivant l'émulation PDO de instructions préparées (par défaut pour MySQL), il vous permet d'utiliser des valeurs paramétrées dans la clause LIMIT. Cette méthode garantit que vos requêtes sont exécutées correctement avec les paramètres spécifiés.
Notez que la désactivation de l'émulation peut avoir un impact sur les performances. Pour plus de détails, référez-vous à la documentation sur PDO MySQL : Utiliser PDO::ATTR_EMULATE_PREPARES ou pas ?.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!