Maison  >  Article  >  base de données  >  Pouvez-vous lier des paramètres de tableau avec la clause LIMIT dans PDO ?

Pouvez-vous lier des paramètres de tableau avec la clause LIMIT dans PDO ?

DDD
DDDoriginal
2024-10-24 01:51:02892parcourir

Can You Bind Array Parameters with LIMIT Clause in PDO?

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn