Maison > développement back-end > tutoriel php > Optimisation des requêtes PHP : méthode pour supprimer les champs inégaux

Optimisation des requêtes PHP : méthode pour supprimer les champs inégaux

WBOY
Libérer: 2024-03-11 09:58:02
original
489 Les gens l'ont consulté

Optimisation des requêtes PHP : méthode pour supprimer les champs inégaux

Titre : Optimisation des requêtes PHP : méthode de suppression des champs inégaux

Lors de l'exécution de requêtes de base de données, nous rencontrons souvent des situations où des conditions spécifiques doivent être filtrées. Parfois, nous devons interroger des données pour lesquelles certains champs ne sont pas égaux à des valeurs spécifiques. Cela nécessite d'optimiser l'instruction de requête pour améliorer l'efficacité. En PHP, nous pouvons utiliser certaines méthodes pour supprimer les champs inégaux afin d'optimiser l'efficacité des requêtes. Cet article présentera certaines méthodes couramment utilisées et donnera des exemples de code spécifiques à titre de référence.

1. Utilisez l'opérateur NOT égal

Dans les instructions SQL, nous pouvons utiliser l'opérateur NOT pour exprimer des conditions qui ne sont pas égales. En PHP, nous pouvons réaliser cette fonction en épissant des instructions SQL. Voici un exemple de code :

<?php
// 连接数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

$conn = new mysqli($servername, $username, $password, $dbname);

// 查询数据
$sql = "SELECT * FROM myTable WHERE myField NOT LIKE '%value%'";

$result = $conn->query($sql);

// 输出结果
if ($result->num_rows > 0) {
    while($row = $result->fetch_assoc()) {
        echo "ID: " . $row["id"]. " - Name: " . $row["name"]. "<br>";
    }
} else {
    echo "0 results";
}

$conn->close();
?>
Copier après la connexion

Dans l'exemple ci-dessus, nous avons utilisé l'opérateur NOT LIKE pour interroger les données indiquant que le champ myField ne contient pas de valeur spécifique.

2. Utiliser le traitement de fonction

En plus d'utiliser directement les opérateurs, nous pouvons également utiliser le traitement de fonction intégré de PHP pour filtrer les champs qui ne sont pas égaux. Par exemple, vous pouvez utiliser la fonction array_filter() pour filtrer les résultats de la requête, comme indiqué ci-dessous :

<?php
// 连接数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

$conn = new mysqli($servername, $username, $password, $dbname);

// 查询数据
$sql = "SELECT * FROM myTable";

$result = $conn->query($sql);

// 处理结果集
if ($result->num_rows > 0) {
    $filteredData = array();

    while($row = $result->fetch_assoc()) {
        if($row["myField"] != "value") {
            $filteredData[] = $row;
        }
    }

    // 输出结果
    foreach($filteredData as $row) {
        echo "ID: " . $row["id"]. " - Name: " . $row["name"]. "<br>";
    }
} else {
    echo "0 results";
}

$conn->close();
?>
Copier après la connexion

Dans l'exemple ci-dessus, nous parcourons les résultats de la requête et utilisons une instruction if pour filtrer les données où se trouve le champ myField. n'est pas égal à une valeur spécifique, stockez les données qualifiées dans le tableau $filteredData et affichez enfin les résultats filtrés.

3. Utilisez des sous-requêtes en SQL

Une autre méthode consiste à utiliser des sous-requêtes en SQL pour filtrer les conditions dans lesquelles les champs ne sont pas égaux. Voici un exemple de code :

<?php
// 连接数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

$conn = new mysqli($servername, $username, $password, $dbname);

// 查询数据
$sql = "SELECT * FROM myTable WHERE id NOT IN (SELECT id FROM myTable WHERE myField = 'value')";

$result = $conn->query($sql);

// 输出结果
if ($result->num_rows > 0) {
    while($row = $result->fetch_assoc()) {
        echo "ID: " . $row["id"]. " - Name: " . $row["name"]. "<br>";
    }
} else {
    echo "0 results";
}

$conn->close();
?>
Copier après la connexion

Dans l'exemple ci-dessus, nous utilisons une sous-requête pour supprimer les données dont le champ myField est égal à une valeur spécifique dans les résultats de la requête, obtenant ainsi les données dont le champ myField n'est pas égal à une valeur spécifique. valeur.

Résumé

Grâce aux méthodes présentées ci-dessus, nous pouvons filtrer les données dont les champs dans les résultats de la requête ne sont pas égaux à des valeurs spécifiques en PHP, optimisant ainsi l'efficacité des requêtes. Dans le développement réel, le choix de méthodes appropriées pour optimiser les conditions de requête en fonction de circonstances spécifiques contribuera à améliorer les performances et l'efficacité du programme.

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal