Maison >développement back-end >tutoriel php >Comment exécuter une requête SELECT avec une sous-requête NOT IN à l'aide de CodeIgniter Active Record ?
CodeIgniter Active Record : Exécution d'une requête SELECT avec une sous-requête NOT IN
Dans ce scénario, vous souhaitez récupérer toutes les lignes du ' table certs qui ne sont pas présents dans la table 'revokace'. La syntaxe SQL conventionnelle pour cette requête serait :
SELECT * FROM certs WHERE id NOT IN (SELECT id_cer FROM revokace);
Pour y parvenir en utilisant le modèle Active Record de CodeIgniter, vous pouvez utiliser la méthode '->where()'. Cependant, il est important de gérer les conflits potentiels avec les caractères spéciaux dans votre requête.
Solution :
La méthode '->where()' de CodeIgniter prend facilement en charge la transmission de requêtes personnalisées. chaînes directement dans la base de données. Cela vous permet d'écrire votre requête comme :
$this->db->select('*') ->from('certs') ->where('`id` NOT IN (SELECT `id_cer` FROM `revokace`)', NULL, FALSE);
Dans cette requête, les arguments 'NULL,FALSE' garantissent que CodeIgniter n'effectue aucun échappement, préservant ainsi l'intégrité de votre sous-requête.
Alternative facultative :
Pour une optimisation plus poussée du code, envisagez d'utiliser la bibliothèque de sous-requêtes CodeIgniter. Il simplifie la création de sous-requêtes en fournissant une interface dédiée. Votre requête utilisant la bibliothèque de sous-requêtes ressemblerait à ceci :
$this->db->select('*') ->from('certs'); $sub = $this->subquery->start_subquery('where_in') ->select('id_cer') ->from('revokace'); $this->subquery->end_subquery('id', FALSE);
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!